HTML --DOM模型(基础)

HTML DOM (文档对象模型)

当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model)。
HTML DOM 模型被构造为对象的树。如下图

AA65CE2D-511A-4BD0-BFC0-974858A70246.png

通过可编程的对象模型,JavaScript 获得了足够的能力来创建动态的 HTML。
JavaScript 能够改变页面中的所有 HTML 元素
JavaScript 能够改变页面中的所有 HTML 属性
JavaScript 能够改变页面中的所有 CSS 样式
JavaScript 能够对页面中的所有事件做出反应

  1. 通过id去获取元素:document.getElementById

     <html>
     <body
     <p id="test">通过id方法来改变我的内容哦</p>
    
     <br>
    
     <button type="button" onclick="changText()">点击我改变上面文本的内容</button>
    
     <script>
    
    function changText(){
    
       var x = document.getElementById('test')
       x.innerHTML = "我是通过id获取元素来改变的"
     }
     </script>
    
     </body>
     </html>
    

上面例子中点击按钮调用JS方法通过元素的id获取到元素,然后改变它的内容

  1. 通过标签名获取所有的标签,document.getElementsByTagName.例子如下

     <html>
     <body>
    
     <p>Hello World!</p>
    
     <p>什么鬼东西啊</p>
    
     <script>
    
     var y=document.getElementsByTagName("p");
     document.write('第二p标签中的第一段文本是:' +                     y[0].innerHTML);
     </script>
    
       </body>
     </html>
    
  2. 改变HTML属性:document.getElementById(id).attribute=new value
    如下例子,点击按钮替换img的src属性

     <html>
     <body>
    
     ![](https://ss0.bdstatic.com/94oJfD_bAAcT8t7mm9GUKT-xh_/timg?image&quality=100&size=b4000_4000&sec=1474525644&di=d19c63d9d54b7a38491c4db1ba1b35fc&src=http://g.hiphotos.baidu.com/image/pic/item/f3d3572c11dfa9ecfc13ccc066d0f703918fc12c.jpg)
    
     <button type="button" onclick="changeImg()">点击切换一个更好看的美女图片行不</button>
    
     <script>
     function changeImg(){
    
      var x = document.getElementById("image")
      x.src = "https://ss0.bdstatic.com/94oJfD_bAAcT8t7mm9GUKT-xh_/timg?image&quality=100&size=b4000_4000&sec=1474525644&di=eabddabe6fac4f92a6158697ab3c0d9d&src=http://e.hiphotos.baidu.com/image/pic/item/314e251f95cad1c8037ed8c97b3e6709c83d5112.jpg"
     }
     </script
     </body>
     </html>
    
  3. 改变 HTML 样式
    document.getElementById(id).style.property=new style
    例子:
    <p id="p2">Hello World!</p>

     <script>
       document.getElementById("p2").style.color="blue";
     </script>
    
  4. 使用 HTML DOM 来分配事件

     <html>
    
     <body>
    
     <p>点击按钮就弹窗</p>
    
     <button id="btn">点我出弹窗</button>
     <script>
      var x = document.getElementById('btn').onclick = function(){alert("该弹窗的要弹窗啊")}
    
     </script>
    
     </body>
     </html> 
    
  5. onload 和 onunload 事件
    onload 和 onunload 事件会在用户进入或离开页面时被触发。
    onload 事件可用于检测访问者的浏览器类型和浏览器版本,并基于这些信息来加载网页的正确版本。
    onload 和 onunload 事件可用于处理 cookie。

    <html>
    <body onload="checkCookies()">

    <script>
  function checkCookies()
{
if (navigator.cookieEnabled==true)
{
alert("已启用 cookie")
}
else
{
alert("未启用 cookie")
}
}
</script>

<p>提示框会告诉你,浏览器是否已启用 cookie。</p>
</body>
</html>

7.onchange 事件
onchange 事件常结合对输入字段的验证来使用。

<p>输入小写字母变大写</p>
<input type="text" id="userName"     onchange="upperName()">

<script>

function upperName() {

  var x = document.getElementById("userName")
  x.value = x.value.toUpperCase();
}
</script>

8.onmouseover 和 onmouseout 事件
onmouseover 和 onmouseout 事件可用于在用户的鼠标移至 HTML 元素上方或移出元素时触发函数

<html>
<body>

<p onmouseover="mouseOn()" onmouseout="mouseM()">鼠标移动到我上面,或者移走都会有不能的效果</p>

<script>

function mouseOn(){

 alert("鼠标移动上来了")
}

function mouseM(){

 alert("鼠标移动走了")
}


</script>

</body>
</html>

9.onmousedown、onmouseup 以及 onclick 事件
onmousedown, onmouseup 以及 onclick 构成了鼠标点击事件的所有部分。首先当点击鼠标按钮时,会触发 onmousedown 事件,当释放鼠标按钮时,会触发 onmouseup 事件,最后,当完成鼠标点击时,会触发 onclick 事件。

 <html>
<body>

<div onmousedown="mDown(this)" onmouseup="mUp(this)" style="background-color:green;color:#ffffff;width:90px;height:20px;padding:40px;font-size:12px;">请点击这里</div>

<script>
function mDown(obj)
{
obj.style.backgroundColor="#1ec5e5";
obj.innerHTML="请释放鼠标按钮"
}

function mUp(obj)
{
obj.style.backgroundColor="green";
obj.innerHTML="请按下鼠标按钮"
}
</script>

</body>
</html>

10 . 创建新的 HTML 元素
如需向 HTML DOM 添加新元素,您必须首先创建该元素(元素节点),然后向一个已存在的元素追加该元素。

  <p>不好意思我需要自己去实现</p>

<div id="yjDiv">

<p>很明显这是一个标签</p>
<p>这是第二个标签</p>

</div>

<button type="button" onclick="appendTag()">新增一个标签</button>


<script>

function appendTag(){

  var pTag = document.createElement("p"); // 创建一个p标签
  var childNode = document.createTextNode("我需要新建一个标签"); // 新建一个节点
  pTag.appendChild(childNode); // 添加节点到元素中

  var newDiv = document.getElementById("yjDiv"); //获取div元素
  newDiv.appendChild(pTag);  // 往元素中添加标签


}

</script>

11.删除已有的HTML元素
如需删除 HTML 元素,您必须首先获得该元素的父元素

<div id="yjDiv">

<p id="yjP">我是段落1</p>
<p id="yjp1">我是段落2</p>

</div>

  <button type="button" onclick="deleteP()">点击删除一个段落</button>

<script>
function deleteP(){

 var parent = document.getElementById("yjDiv"); // 获取父元素
 var child = document.getElementById("yjP"); // 获取需要删除的标签
 parent.removeChild(child)
}
</script>

11、获取浏览器内部窗口的宽高(不包括内滚动条/工具栏)

<p id ="test">点击下面的按钮获取窗口的宽高</p>

<button type="button" onclick="getWindowInfo()">点击获取</button>

<script>
  function getWindowInfo() {

   var h=window.innerHeight||document.documentElement.clientHeigh||document.body.clientHeigh;
var w = window.innerWidth || document.documentElement.clientWidth||docuemnt.body.clientWidth;


var x = document.getElementById("test");

x.innerHTML = "获取到的宽高 "+ w +",高度:"+ h +""

}
</script>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容