javascript(二)之HTMLDOM
来源:互联网 发布:淘宝女模特名字大全 编辑:程序博客网 时间:2024/05/18 12:04
HTML DOM (文档对象模型)
当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model)。
HTML DOM 模型被构造为对象的树。
通过可编程的对象模型,JavaScript 获得了足够的能力来创建动态的 HTML。
- JavaScript 能够改变页面中的所有 HTML 元素
- JavaScript 能够改变页面中的所有 HTML 属性
- JavaScript 能够改变页面中的所有 CSS 样式
- JavaScript 能够对页面中的所有事件做出反应
改变 HTML 属性
如需改变 HTML 元素的属性,请使用这个语法:
document.getElementById(id).attribute=new value
实例
本例改变了 <img> 元素的 src 属性:
<!DOCTYPE html><html><body><img id="image" src="smiley.gif"><script>document.getElementById("image").src="landscape.jpg";</script></body></html>
改变 HTML 样式
如需改变 HTML 元素的样式,请使用这个语法:
document.getElementById(id).style.property=new style
例子 1
下面的例子会改变 <p> 元素的样式:
<p id="p2">Hello World!</p><script>document.getElementById("p2").style.color="blue";</script>
- 执行点击事件
- <button type="button" onclick="my()">点击这里</button></body>
<button type="button" onclick="document.getElementById('demo').style.color='red'">点击这里</button></body> - <input type="button" value="隐藏文本" onclick="document.getElementById('demo').style.visibility='hidden'" />
<input type="button" value="显示文本" onclick="document.getElementById('demo').style.visibility='visible'" />
HTML 事件属性
如需向 HTML 元素分配 事件,您可以使用事件属性。
向 button 元素分配 onclick 事件:
<button onclick="displayDate()">点击这里</button>
<h1 onclick="this.innerHTML='谢谢!'">请点击该文本</h1>
2.HTML DOM 允许您通过使用 JavaScript 来向 HTML 元素分配事件:
向 button 元素分配 onclick 事件:
<p>点击按钮就可以执行 <em>displayDate()</em> 函数。</p>
<button id="myBtn">点击这里</button>
<script>
document.getElementById("myBtn").onclick=function(){displayDate()};
function displayDate()
{
document.getElementById("demo").innerHTML=Date();
}
</script>
<p id="demo"></p>
</body>
onload某个元素加载完成时调用,
onunload 事件会在用户离开页面时被触发。
onload 事件可用于检测访问者的浏览器类型和浏览器版本,并基于这些信息来加载网页的正确版本。
onload 和 onunload 事件可用于处理 cookie。
onchange 事件,当改变事件状态时,常结合对输入字段的验证来使用。
<body>
<div onmouseover="mOver(this)" onmouseout="mOut(this)" style="background-color:green;width:120px;height:20px;padding:40px;color:#ffffff;">把鼠标移到上面</div>
<script>
function mOver(obj)
{
obj.innerHTML="谢谢"
}
function mOut(obj)
{
obj.innerHTML="把鼠标移到上面"
}
</script>
</body>
</html>
- onfocus文本框获得焦点时调用;
- //====创建新的html元素=================
向 HTML DOM 添加新元素,您必须首先创建该元素(元素节点),然后向一个已存在的元素追加该元素。
<div id="div1">
<p id="p1">这是一个段落。</p>
<p id="p2">这是另一个段落。</p>
</div>
<script>
function myadd(){
var para=document.createElement("p");//创建新的元素
var node=document.createTextNode("这是新段落。");//穿件元素的文本节点
para.appendChild(node);//向p元素追加这个文本节点
var element=document.getElementById("div1");//获得div元素
element.appendChild(para);//向div元素后追加p元素
}
</script>
<button type="button" onclick="myadd()">点击这里添加一个p段落</button></body>
删除已有的 HTML 元素
如需删除 HTML 元素,您必须首先获得该元素的父元素:
<div id="div1">
<p id="p1">这是一个段落。</p>
<p id="p2">这是另一个段落。</p>
</div>
<script>
function myadd(){
var para=document.createElement("p");
var node=document.createTextNode("这是新段落。");
para.appendChild(node);
var element=document.getElementById("div1");
element.appendChild(para);
}
function mydel(){
var parent=document.getElementById("div1");
var child=document.getElementById("p1");
parent.removeChild(child);
//或者可以写成下面的
找到您希望删除的子元素,然后使用其 parentNode 属性来找到父元素:
var child=document.getElementById("p1");child.parentNode.removeChild(child);
}
</script>
<button type="button" onclick="myadd()">点击这里添加一个p段落</button></body>
<button type="button" onclick="mydel()">点击这里添加删除id为p1段落</button></body>
- javascript(二)之HTMLDOM
- HTMLDOM
- HTMLDOM
- js 操作HtmlDom 学习笔记二
- javascript(二) JavaScript之创建类
- javaScript之数组(二)
- javascript之(二)DOM
- javascript之DOM技术(二)
- robotframeowk之execute javascript(二)
- JavaScript对象(二)之Array对象
- Unity3D动画制作之二(javascript)
- javascript正则表达式之小结(二)
- 深入JavaScript(二)之解析机制
- JavaScript动画工作原理之(二)
- 深入JavaScript(二)之解析机制
- 牛腩javascript(二)之正则表达式
- JavaScript学习笔记之(二)
- JavaScript基础知识之Array类型(二)
- python 函数传参是传值还是传引用
- js实现点击按钮复制文本框中的内容
- Android和js代码互相调用
- AngularJs-注意问题(待更新)
- unity编译Android工程时链接不上服务器,可能是因为unity没有开通网络权限
- javascript(二)之HTMLDOM
- STM32 HAL库、标准外设库、LL库(STM32 Embedded Software)
- golang获取并解析ajax请求参数(带数组)
- Spring MVC 对CORS的支持
- 关于Uboot启动之后进入SMDKV210引导,minicom下无法键入任何内容
- 跳转到页面固定位置
- 本文的内容是总结了一下iOS开发中NSLog输出格式大全
- krpano全景之解决微信内置浏览器不能自动播放音频的问题
- 王学岗音乐设置成闹钟