前端页面js与flash交互——js获取flash对象,并传递参数

背景介绍

  最近在搞一个项目,涉及到图片选取,裁剪,上传等,由于浏览器安全性问题,js无法获取到<input
type="file">中选取的文件路径,而且对照片的裁剪,抠图等由HTML5实现的功能,对各大浏览器的兼容性,真是不敢太大胆。这个时候就引进了flash,然后所有js做不了的让flash来做,然后由js来控制页面元素。就这样开始了js与as的交互之旅,听做flash的大叔说,flash调js的函数式很好调的,而js调as不大容易。最终的情况是as调js错误层出不穷,花费了很多时间在上面,当然了,期初js调as也走了弯路,因为之前没有跟flash打过交道,所以只能任由别人说了,但是貌似还不是咱们js的问题,因为网上现成的方法就很多的了,废话不多说,把项目中js调用as的代码共享出来。

重要内容

//获取flash对象
function getSWF(name){
var
e=document.getElementById(name);
return
(navigator.appName.indexOf("Microsoft") !=
-1)?e:e.getElementsByTagName("embed")[0];
}

为什么要这样呢,因为在浏览器中嵌入flash一般采用如下格式:

<object>

<embed></embed>

</object>

因为IE(微软家的),其他(Mozilla家的火狐,谷歌家的chrome等等)在对HTML文档进行解析的时候存在差异,所以如果面对不同的浏览器,通用一个方法,自己都不知道错在哪里,但是你真的错了!

代码详解

上面的函数getSWF()顾名思义,就是获取文档中嵌入的flash对象,navigator是浏览器对象,Navigator
对象中包含有关浏览器的信息。

相关的信息可参考:http://www.w3school.com.cn/jsref/dom_obj_navigator.asp

所以后面的appName就是Navigator对象中叫“appName”的属性,这个属性记录了navigator.appName获取到的是浏览器的名称,当前5大主流浏览器的appName值如下:

IE:                  
                     
       浏览器名称:Microsoft Internet

FF,Chrome,Opera,Safari:            
    浏览器名称:Netscape

浏览器appName测试地址:http://www.w3school.com.cn/tiy/t.asp?f=hdom_browser

indexOf()是Javascript函数,indexOf()
方法可返回某个指定的字符串值在字符串中首次出现的位置

stringObject.indexOf("str",num);stringObject就是被查找的字符串对象,str是要查找的字符串,num是起始位置,如果查询到了“str”字符串存在于stringObject中,则返回第一个出现的位置,如果要检索的字符串值没有出现,则该方法返回
-1;

var e = document.getElementById(name);
是获取文档中属性id的值为name的节点对象,并把这个对象赋给e,

return (navigator.appName.indexOf("Microsoft") !=
-1)?e:e.getElementsByTagName("embed")[0];看上去好像很复杂,起始很简单的,这里是一个三木运算(学过编程的都应该知道),具体的格式为
if(a)?b:c;意思就是当if(a)为true时取值为b,if(a)不为true时,取值为c。可以把这句长长的代码分解成if(a)?b:c;的格式
navigator.appName.indexOf("Microsoft")!=-1
        e        
e.getElementsByTagName("embed")[0]  
 这三个部分

if(navigator.appName.indexOf("Microsoft")!=-1){
   alert("我的浏览器不是IE内核的");  
}else{"我的浏览器是IE内核的"}
当弹窗为“我的浏览器不是IE内核的”
的时候说明我的浏览器的名称中没有包含“Microsoft”,就是说没有用IE浏览器,这个时候要获取的flash对象就是文档中的<object></object>对象,如果是IE浏览器,则获取到的是<embed></embed>这个对象,无论获得那个对象,最终都要用return返回给调用的函数,这样就可以在不同的浏览器里获得相对应的flash对象。

整体方案:

获取了flash
对象之后就可以调用flash里面的方法,或者flash里面的属性了。

var objName = getSWF("FlashToJS");

//调用对象的flash_selFiles方法
if(objName){

objName.flash_cutPic(arg);
}else{
console.log("没有获取到对象");

}

这就调到了flash里里面的flash_selFiles()方法。

最后的感言

在页面中还是尽量减少使用flash,特别是别对flash太过于依赖,在as与js的交互中还是隐藏着很多的陷阱的。报告完毕!

前端页面js与flash交互——js获取flash对象,并传递参数

时间: 2024-12-26 16:03:04

前端页面js与flash交互——js获取flash对象,并传递参数的相关文章

iOS JS 和 OC交互 / JS 和 native 相互调用

现在app 上越来越多需求是通过UIWebView 来展示html 或者 html5的内容, js 和 native OC代码交互 就非常常见了. js 调用 native  OC代码 第一种机制 (1)最常用的是 利用 - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationT

Python之路-(js正则表达式、前端页面的模板套用、Django基础)

js正则表达式 前端页面的模板套用 Django基础 js正则表达式: 1.定义正则表达式 /.../  用于定义正则表达式 /.../g 表示全局匹配 /.../i 表示不区分大小写 /.../m 表示多行匹配 登录注册验证: test: 判断字符串是否符合规定的规则 rep = /\d+/;   (定义规则) rep.test('')   (引号里面必须包含字母和数字才返回true,否则为false) rep = /^\d+$/; (只有是纯数字时候才返回true,否则是false) exe

[转载]解决flash与js交互、flash跨域交互、flash跨域提交

http://blog.csdn.net/andyxm/article/details/5219919 我们引用本地flash,实现flash与js双向交互. function thisMovie(movieName) {     if (window.document[movieName]){      return window.document[movieName];    }else if (navigator.appName.indexOf("Microsoft")==-1)

前端页面——js如何让数据传输更灵活

我们之前已经说过一些关于前端页面的问题,今天我们来说说数据如何在页面和部分视图之间传递. 我们的项目中最基本的功能就是增.删.改.查.那么我们在实现的时候就会在主视图上添加一些部分视图,页面加载的时候我们先影藏部分视图,当单击添加或者修改的时候,再显示相应的部分视图.那么当我们在修改的时候,数据是如何变化的呢? 一.整体过程图 我们先来看看这个变化过程的整体图. 二.过程讲解 1.页面加载 已组织机构页面为例,当我们加载时,需要查询出所有的组织机构 1.1主视图的加载url <div id=&quo

js学习总结----crm客户管理系统之前端页面开发及数据渲染

具体代码如下: index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <link rel="stylesheet" href="css/index.css" charset='utf-8'> </h

jsp页面和js代码中使用sessionScope获取session值

场景:有些实体对象可以放到HttpSession对象中,保正在一个会话期间可以随时获取这个对象的属性,例如可以将登录用户的信息写入session,以保证页面随时可以获取并显示这个用户的状态信息.下面以此为例. 本文转自:http://blog.csdn.net/baidu_30809315/article/details/77159549 1.后台将用户这一实体对象写入session(HttpSession),这里是从拦截器中写入,代码中的userInfo是从单点登录服务器获取的登录用户信息 [

js中escape的用法----前端页面简单加密

escape() 方法,它用于转义不能用明文正确发送的任何字符.比如,电话号码中的空格将被转换成字符 %20,从而能够在 URL 中传递这些字符. http://localhost:8080/a?name="+escape("aa")+"&password="+escape("中华人民共和国"); alert(s); js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个

flash和js相互交互

Flash代码: package { import flash.display.Sprite; import flash.events.*; import flash.external.ExternalInterface; import flash.text.TextField; import flash.utils.Timer; import flash.text.TextFieldType; import flash.text.TextFieldAutoSize; public class

CeF3开发者系列之外篇——IE中JS与C++交互

使用IE内核开发客户端产品,系统和前端页面之间的交互,通常给开发和维护带来很大的便利性.但操作系统和前端之间的交互却是比较复杂的.具体来说就是脚本语言和编译语言的交互.在IE内核中html和css虽然不兼容,但是IE编程接口是完全一样的,这得益于微软的COM组件的结构化设计和实现.所以与IE交互,必须得先说一下COM,COM全称组件对象模型(Component Object Model). COM的基本思想很简单,所有的组件模块都提供一个最根本的接口, IUnkown,它有三个方法,AddRef