久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

HTML插入Flash的全兼容完美解決方案-SWFObject

Flash 嵌入的問題朋友們可能認為很簡單,但是具體到一些問題上來講,就不是那么簡單了,比如:IE瀏覽器對FLASH的攔截虛框怎么去掉?在FF、OP、NS等其它瀏覽器是否兼容?代碼是否符合

        Flash 嵌入的問題朋友們可能認為很簡單,但是具體到一些問題上來講,就不是那么簡單了,比如:IE瀏覽器對FLASH的攔截虛框怎么去掉?在FF、OP、NS等其它瀏覽器是否兼容?代碼是否符合W3C標準??等等

        下面我就轉貼別人的一篇文件,共同學習一下

一、傳統的方法

<object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000"codebase="http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=7,0,0,0" width="550" height="400" id="Untitled-1" align="middle"> 
<param name="allowScriptAccess" value="sameDomain" /> 
<param name="**" value="my**.swf" /> 
<param name="quality" value="high" /> 
<param name="bgcolor" value="#ffffff" /> 
<embed src="my**.swf" quality="high" bgcolor="#ffffff" width="550"    height="400"name="my**" align="middle" allowScriptAccess="sameDomain"    type="application/x-shockwave-flash" pluginspage="http://www.macromedia.com/go/getflashplayer" /> 
</object>

      這方法是使用 object 和 embed 標簽來嵌入,細心的會發現,object 的很多參數和 embed 里面的很多屬性是重復的,為什么這樣做?為了瀏覽器兼容性,有的瀏覽器支持 object,有的支持 embed,這也是為什么要修改 Flash 的參數時兩個地方都要改的原因。

 

      這種方法是 Macromedia 一直以來的官方方法,最大限度的保證了 Flash 的功能,沒有兼容性問題。但是它現在不那么好用了: 無法通過驗證,由于為了兼容性而嵌入的 embed 標簽是不符合 W3C 的規范的。當然,如果你不在乎什么規范不規范,另當別論。

      微軟由于種種原因,在 sp2 后限制了 IE 的 ActiveX 的使用模式,就是在頁面中的 ActiveX 有一個虛框,需要用戶點擊一次才能正常交互。Flash是作為一個 ActiveX 嵌入到網頁中的,所以它也會受牽連,只有通過 JS 嵌入 Flash 才能解決這個問題。

       沒有 Flash 版本檢測,如果版本瀏覽器的flash插件版本不夠,或者不能正常顯示你的 swf 文件,或者會彈出一個 ActiveX 的確認安裝的框——這個框對很多用戶來說是很恐怖的。

二、用JS嵌入的方法

      用JS嵌入就是各有各的嵌入方法了,有嵌得好的有嵌得不好的。有人用 document.write 直接寫,這法子說實話不大好,感覺 hack 成分多了,有點為了驗證而驗證的意思,而且沒有體現出什么 JS 的優勢。我覺得一個好的 JS 嵌入腳本,在保證 Flash 應有功能的基礎上,要發揮 JS 的優勢應該要有版本檢測,要能很好解決可訪問性問題(也就是用戶在無法瀏覽 Flash 內容或禁用 JS 的時候應該如何處理的問題),要易于重復使用。

      我們這里要講的是SWFObject這個解決方案:

      “SWFObject”是利用Javascript 插入flash,好處多多,代碼簡潔,不會出現IE6下的“單擊此處以激活控件”的提示,并且能通過W3C驗證。不同于傳統的“object”插入flash的方法。

       SWFObject在新的2.x版本中,其最簡單的調用竟只需一句話,并且不需要等待頁面加載完成,這意味著你可以將這句話寫在頁面的任何地方。比以前的版本,要簡便多了。下面來看幾個簡單常用的調用方法:

1、最簡單,最基本,只要想插入flash都能用到的經典一句話。

<div id="swfid"></div> 
<script type="text/javascript" src="swfobject.js"></script> 
<script type="text/javascript">
swfobject.embedSWF("test.swf", "swfid", "300", "120", "9.0.0", "expressInstall.swf"); 
</script>

注解:調用方法embedSWF——插入SWF文件,參數依次是@swf文件的地址;@用于裝入swf文件的容器(如div)的id;@flash的寬度;@flash的高度(當然,這里的寬高都可以使用諸如100%這樣的百分比來表示);@正常播放該flash所需的最低版本;@當版本低于要求時,執行該swf文件,這里利用這個flash跳轉到官方下載最新版本的flash插件。(該參數可以省略)在同一個頁面插入多個flash到不同位置時,只要重復上面的語句,使用不同的容器id就可以了。


2、給swf文件傳遞參數、變量、屬性的調用方法

<script type="text/javascript" src="swfobject.js"></script> 
<script type="text/javascript"> 
//1、使用Json初始化變量、參數、屬性 
        var flashvars = {
            name1: "hello",
            name2: "world",
            name3: "foobar"
        };
        var params = {
            menu: "false"
        };
        var attributes = {
            id: "dynamicContent2",
            name: "dynamicContent2"
        };
        swfobject.embedSWF("test6_flashvars.swf", "content2", "300", "120", "6.0.0","expressInstall.swf", flashvars, params, attributes); 

//2、傳統的初始化設置,效果一樣 
        var flashvars = {};
        flashvars.name1 = "hello";
        flashvars.name2 = "world";
        flashvars.name3 = "foobar";
        var params = {};
        params.menu = "false";
        var attributes = {};
        attributes.id = "dynamicContent3";
        attributes.name = "dynamicContent3";
        swfobject.embedSWF("test6_flashvars.swf", "content3", "300", "120", "6.0.0","expressInstall.swf", flashvars, params, attributes); 

//3、直接寫在后面,就一句話,簡潔剽悍,不拖泥帶水 

        swfobject.embedSWF("test6_flashvars.swf", "content5", "300", "120", "6.0.0","expressInstall.swf", {name1:"hello",name2:"world",name3:"foobar"}, {menu:"false"}, {id:"dynamicContent5",name:"dynamicContent5"}); 
</script>
 

SWFObject google 開源項目 http://code.google.com/p/swfobject/
SWFObject(2.2版) 下載地址:http://swfobject.googlecode.com/files/swfobject_2_2.zip
SWFObject(2.0版) 下載地址:http://swfobject.googlecode.com/files/swfobject_2_0.zip
SWFObject的官方Blog:http://blog.deconcept.com/swfobject/
SWFObject 2.0 官方文檔(中文) http://www.admin10000.com/resource/1.html

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

由于實際運行環境是在瀏覽器中,因此性能還取決于JavaScript解釋器的效率,指定的FPS幀速在低性能解釋器中可能不會達到,所以這部分不是開發者能夠決定的,開發者能作的是盡可能通
本文將使用HTML5提供的VideoAPI做一個自定義的視頻播放器,需要用到HTML5提供的video標簽、以及HTML5提供的對JavascriptAPI的擴展。,HTML5中國,中國最大的HTML5中文門戶。
隨著 Hybrid 應用的豐富,HTML5 工程師們已經不滿足于把桌面端體驗簡單移植到移動端,他們覬覦移動原生應用人性化的操作體驗,特別是原生應用與生俱來的豐富的手勢系統。HTML5 沒有提
你想要在自己網站上分享一個產品,或者是一個作品集,又或者僅僅只是一個靈感。在你發布到網上之前,你想讓它看起來有吸引力,專業,或者至少得看起來像那么回事。那么你接下
H5廣告,包括H5廣告的設計流程,究竟有什么講究,和階段。為了能幫助更多的人了解H5廣告,我專門做了一個講義。同時,也讓我意外的收到了非常好反饋和認!這是對我的極大鼓勵!我的
本文主要內容有:框架與組件、構建生態、開發技巧與調試、html、css與重構、native/hybrid/桌面開發、前端/H5優化、全棧/全端開發、研究實驗、數據分析與監控、其它軟技能、前端技術網
主站蜘蛛池模板: 国产成人久久精品一区二区三区 | 欧美精品在线一区二区三区 | 中文字幕成人免费视频 | 91影片| 超碰av免费| 午夜欧美 | 日韩日b视频| 国产日韩精品一区 | 成人在线视频免费看 | 黄色91在线 | 国产成人91视频 | 久久91精品国产一区二区三区 | 91欧美精品成人综合在线观看 | 羞羞视频网站免费观看 | 日韩一区二区视频 | 91久久精品一区二区二区 | 国产成人精品一区 | 9久久婷婷国产综合精品性色 | 中文字幕 国产 | 国产精品久久久久久久久久免费看 | 国产在线91| 天天夜夜人人 | 免费网站在线 | 国产999精品久久久久久 | 午夜精品久久久久久久久久久久久 | 91福利在线观看视频 | 日韩电影免费在线观看中文字幕 | 一区二区精品视频 | 国产亚洲黄色片 | 色毛片 | 欧美在线天堂 | 日本精品国产 | 国产成人免费 | 久久久性 | 国产91丝袜在线18 | 亚洲一区中文字幕在线观看 | 在线观看涩涩视频 | 亚洲日本国产 | 欧美精品在线一区二区三区 | 亚洲一区二区不卡在线观看 | www4虎|