首页 > temp > JavaScript教程 >
-
javascript 09 web API DOM
API应用程序编程接口,是一些预先定义的函数,或方法。
任何开发语言都有自己的API
API的特征是输入和输出(I/O )
Web API 是浏览器提供的一套操作浏览器功能和页面元素的API(BOM和DOM)
DOM经常进行的操作:
获取元素
对元素进行操作(设置属性或方法)
动态创建元素
事件
获取网页上的元素,返回一个对象:document.getElementById(),doucemnt.getElementsByTagName(' ') //id唯一,所以element不是复数,而Tag Name标签名可能很多不唯一,所以是复数
document.getElementById() 返回一个对象
doucemnt.getElementsByTagName(' ') 返回一个集合对象(动态集合,无关html执行顺序,都可以获取到),有索引,也可遍历
定义一个变量接受标签的id属性(一般和id名称一致) var main= doucument.getElementById('id名') //get 获取,element 元素,by 根据,id 表标示
main= doucument.getElementById('id名'),main是一个对象。输出对象用console.dir(),可以输出所有属性和方法
获取二级标签:
<div id = "name">
<div>123</div>
<div>456</div>
</div>
var name = document.getElementById('name');
var divs = name.getElementsByTagName('div'); //利用返回的name对象的属性,主要:id只能通过document对象来调用
其他获取元素的方法:有兼容问题,查文档
选择器获取:document.querySelector() id选择器可以获取一 个,类选择器只能获取到第一个
document.querySelectorAll() //获取所有
事件:当什么时候做什么事 触发-响应 。事件都是on开头,是 当……的时候 的意思。例如onclick,当点击的时候。事件名称不是onclick,是click
<input type="button" id='bun' value='点我'> //制作一个按钮
bun=document.getElementById('bun');
bun.onclick = function(){alert('don't touch me!')} //设置事件处理函数
获取的元素一般和对应的标签有相同的属性: //注意,DOM对象的对应标签的class属性名字叫做className,因为class是关键字,关键字不可以作为属性名字
点击换图片案例:
<img src = "xxx" id='sss'> <input type="button" id='bun' value='点我'> <script> var sss = document.getElementById('sss'); bun=document.getElementById('bun'); var flag = 1; //通过控制flag的数值来实现图片循环切换 //通过更改属性值来实现点击切换图片 bun.onclick = function(){ if(flag===1){ sss.src="yyy"; flag = 2; }elseif(flag===2){ sss.src="xxx"; flag =1; } }; </script>
事件处理函数中的this:指向事件源,即调用该事件的对象
js控制css样式:object.style.display = 'none'; //开发的时候css可能是别人写的,在不改变代码的前提下修改css就需要自己再写一个样式,通过class或者id来改变
取消<a>的默认行为(跳转):
<a id = "qwe" href="xxxxx">百度</a> qwe = document.getElementById('qwe'); qwe.onclick = function(){return false;} //在事件中return false,超链接就不跳转了
获取标签集合的时候,需要其中每个标签触发事件可以用this。this指向事件源,即标签集合中的各个元素而不是标签的集合整体
<div id="kuai"> <a href=""> <img src=""> </a> <a href=""> <img src=""> </a> <a href=""> <img src=""> </a> <a href=""> <img src=""> </a> </div> var kuai = document.getElementById('kuai'); //jihes 是a标签的集合 var jihes = kuai.getElementsByTagName('a'); for (var i = 0; i < jihes.length; i++) { var jihe = jihes[i]; jihe.onclick = function(){ var image = document.getElementById('image'); image.src = this.src; //此处只能用this不能用jihe。因为事件是在浏览器执行完代码之后触发的。用jihe.src的话只能找到最后一个遍历值。而this指向事件源,即遍历的元素中触发了事件的对象 return false; } }
来源:https://www.cnblogs.com/xiaoyuheng/p/14851191.html