需要准备的材料分别是:电脑、html编辑器、浏览器。
1、首先,打开html编辑器,新建html文件,例如:index.html,引入jquery使用。
2、在index.html的<script>标签中,输入js代码:
$.get('请求地址', function(b) {
document.body.innerText = b
})
3、浏览器运行index.html页面,此时通过F12的开发者工具可知API接口被调用了。
Document Object Model文档对象模型(JS用document操作网页)
Application Programming Interface应用程序接口,是一些预先定义的接口(函数,HTTP接口)
Chrome会有显示错误
自身属性:className、id、style等等
第一层 原型 HTMLDivElement.prototype :这是所有div共有的属性
第二层 原型 HTMLElement.prototype :这是所有HTML标签共有的属性
第三层 原型 Element.prototype :这是所有XML、HTML标签共有的属性
第四层 原型 Node.prototype :这是所有节点共有的属性,包括XML标签文本注释、HTML标签文本注释等等
第五层 原型 EventTarget.prototype :里面最重要的函数属性是addEventListener
第六层 原型 Object.prototype
MDN中相关知识
创建一个标签节点
创建一个文本节点
标签里插入文本
插入页面中
创建的标签默认处于JS线程中,必须把它插入到head或者body里面才会生效, document.body.appendChild(div) 或者已在页面中的 元素.appendChild(div)
appendChild
假设页面中有div#test1和div#test2
那么div最终会出现在哪里呢?
答案:只在test2中,一个元素不能出现在两个地方,除非复制一份 node.cloneNode
如果一个node被移除页面(DOM树)那么他还可以再次回到页面中吗?
改class
改style
改style的一部分
注意大小写
改date属性
正常/特殊的读属性
(特殊)若使用
需要使用
这两种方法都可,但是值可能稍有不同
改事件处理函数
div.onclick 默认为null,默认点击div不会发生任何事,但是如果把 div.onclick 改为一个函数fn,那么点击div的时候,浏览器就会调用这个函数,并且是这样调用的 fn.call(div,event) ,div会被当做this,event则包含了点击事件的所有信息(如:坐标)
div.addEventListener 是 div.onclick 的升级版,后面会说明
查爸爸
查爷爷
查儿子
查兄弟姐妹
遍历div里面所有的元素
浏览器有渲染引擎和JS引擎
各线程各司其职。JS引擎不能操作页面只能操作JS;渲染引擎只能操作页面。
那么
这句JS是如何改变页面的呢?
跨线程通讯
当浏览器发现JS在body里面加了div1对象,就会通知渲染引擎在页面里也新增一个div元素,新增的div元素所有属性都照抄div1对象
JS线程中的所有属性叫做 div1的property
渲染引擎中div1对应标签的属性叫做 Attribute
区别
在Flex开发中有时候需要调用JS代码,例如关闭浏览器,或者是在某种情况下打开浏览器提示框等等。一般情况下Flex用ExternalInterface类的call()函数来调用JS代码,其中call()函数的参数就是String类型的JS代码段。你可以调用Html页面中的JavaScript,通过与JavaScript的交互,可以改变Style,调用远程方法。还可以将数据传递给Html页
面,处理后再返回给Flex,完成这样的功能主要有两种方法:ExternalInterface()和navigateToUrl()。
在Flex调用JavaScript最简单的方法是使用ExternalInterface(),可以使用此API调用任意JavaScript,传递参
数,获得返回值,如果调用失败,Flex抛出一个异常。ExternalInterface封装了对浏览器支持的检查,可以用available属性来查
看。ExternalInterface的使用非常简单,语法如下:
flash.external.ExternalInterface.call(function_name:String[,arg1,...]):Object
参数function_name是要调用的JavaScript的函数名,后面的参数是JavaScript需要的参数。
As代码
ExternalInterface.call(FUNCTION_USEREXIT)
ExternalInterface.addCallback("checkExit",checkExit)
privatestaticvarFUNCTION_USEREXIT:String="document.insertScript=function()"+"
{"+"window.onbeforeunload=function()"+"{"+"varflexObj=MarineDataEdit.checkExit()
"+"if(flexObj!="")"+"{"+"returnflexObj"+"}else{"+"return"+"}"+"}"+"}"
publicfunctioncheckExit():String{varuserExitStr:String="你如果现在离开,则您的所有信息将失效!"
returnuserExitStr
ExternalInterface.call(FUNCTION_USEREXIT)
ExternalInterface.addCallback("checkExit",
checkExit)privatestaticvarFUNCTION_USEREXIT:String="document.insertScript=function()"+"
{"+"window.onbeforeunload=function()"+"{"+"varflexObj=MarineDataEdit.checkExit()
"+"if(flexObj!="")"+"{"+"returnflexObj"+"}else{"+"return"+"}"+"}"+"}"
publicfunctioncheckExit():String{varuserExitStr:String="你如果现在离开,则您的所有信息将失效!"
returnuserExitStr
其中ExternalInterface类的addCallback函数是调用AS端的返回值。