首頁 > web前端 > js教程 > 深入學習JavaScript之DOM

深入學習JavaScript之DOM

青灯夜游
發布: 2019-11-27 18:15:32
轉載
2345 人瀏覽過

通过HTML DOM,可访问JavaScript HTML文档的所有元素。下面本篇文章就来给大家介绍一下,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

深入學習JavaScript之DOM

DOM能干啥?

● JavaScript 能够改变页面中的所有 HTML 元素

● JavaScript 能够改变页面中的所有 HTML 属性

● JavaScript 能够改变页面中的所有 CSS 样式

● JavaScript 能够对页面中的所有事件做出反应

【相关课程推荐:JavaScript视频教程

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

深入學習JavaScript之DOM

查找元素方法:

1、直接查找:

● getElementByid():    通过 id 找到 HTML 元素

● getElementsByTagName():    通过标签名找到 HTML 元素(列表)

● getElementsByClassName():    通过类名找到 HTML 元素(列表)

● getelementsByName():    通过name属性找到HTML元素(列表)

2、间接查找:

      parentNode  父节点
    childNodes     所有子节点
    firstChild        第一个子节点
    lastChild     最后一个子节点
    nextSibling     下一个兄弟节点
    previousSibling   上一个兄弟节点
    parentElement    父节点标签元素
    children          所有子标签
    firstElementChild   第一个子标签元素
    lastElementChild   最后一个子标签元素
    nextElementtSibling    下一个兄弟标签元素
    previousElementSibling   上一个兄弟标签元素
登入後複製

3、添加删除节点和元素:

操作方法:

innerText    文本,指定ID下所有文本的拼接,去除间隔的HTML元素
outerText  写模式下,替换所有子元素
innerHTML    会根据指定的值创建新的 DOM 树,然后用这个 DOM 树完全替换调用元素原先的所有子节点。
outerHTML    写模式下,新的元素替换原有的 DOM 树
value         属性可设置或返回密码域的默认值。获取文本框的值。
登入後複製

Class属性操作(CSS样式表名):

className 获取所有类名
classList.remove(cls) 删除指定类
classList.add(cls)  添加类
登入後複製

checkbox属性:

checkbox.checked:true选中,false不选
登入後複製

tag标签操作:

1、createElement()创建标签:

每个HTML标签都有自己的属性,属性参照:https://www.w3school.com.cn/jsref/dom_obj_anchor.asp

function append_tag(){
   var a = document.createElement('a')
   var cur = document.getElementById('dd')
   a.innerHTML='click me'
   a.href='http://www.baidu.com'
   a.className='a1'
   cur.appendChild(a)    //添加标签}\\----------等同于
var a_tag="<a class=&#39;a1&#39; href=&#39;>click me</a>"
登入後複製

2、操作标签:

insertAdjacentText('位置',obj) 在指定的地方插入文本内容,如果是HTML对象会以文本形式显示出来

insertAdjacentHTML('位置',obj) 在指定的地方插入html内容

位置说明:

beforeBegin:标签起始位置前(标签前)
afterBegin:标签起始位置后(标签内)
beforeEnd:标签结束位置前(标签内)
afterEnd:    标签结束位置后(标签外)
登入後複製

3、标签样式操作style:

var obj = document.getElementById(&#39;i1&#39;)
obj.style.fontSize = "32px";
obj.style.backgroundColor = "red";
登入後複製

4、位置操作

document.documentElement.offsetHeight    总文档高度
document.documentElement.clientHeight    当前文档占屏幕高度
tag.offsetHeight    自身高度
tag.offsetTop    距离上级定位高度
tag.offsetParent 父定位标签
tag.scrollTop 滚动高度
登入後複製
/*
    clientHeight -> 可见区域:height + padding
    clientTop    -> border高度
    offsetHeight -> 可见区域:height + padding + border
    offsetTop    -> 上级定位标签的高度
    scrollHeight -> 全文高:height + padding
    scrollTop    -> 滚动高度
    特别的:
        document.documentElement代指文档根节点
*/
登入後複製

事件:

addEventListener() 方法用于向指定元素添加事件句柄。

addEventListener() 方法添加的事件句柄不会覆盖已存在的事件句柄。

你可以向一个元素添加多个事件句柄。

你可以向同个元素添加多个同类型的事件句柄,如:两个 "click" 事件。

你可以向任何 DOM 对象添加事件监听,不仅仅是 HTML 元素。如: window 对象。

addEventListener() 方法可以更简单的控制事件(冒泡与捕获)。

当你使用 addEventListener() 方法时, JavaScript 从 HTML 标记中分离开来,可读性更强, 在没有控制HTML标记时也可以添加事件监听。

你可以使用 removeEventListener() 方法来移除事件的监听。

语法:

element.addEventListener(event, function, useCapture);
登入後複製

事件类型:

屬性
此事件發生在何時...#此事件發生在何時...
onabort映像的載入被中斷。 onload一張頁面或一個圖片完成載入。
onblur元素失去焦點。 onmousedown滑鼠按鈕被按下。
onchange網域的內容被改變。 onmousemove滑鼠被移動。
onclick當使用者點擊某個物件時所呼叫的事件句柄。 onmouseout滑鼠從某元素移開。
ondblclick當使用者雙擊某個物件時所呼叫的事件句柄。 onmouseover滑鼠移到某元素之上。
onerror在載入文件或映像時發生錯誤。 onmouseup滑鼠按鍵被放開。
onfocus元素獲得焦點。 onreset重置按鈕被點選。
onkeydown某個鍵盤按鍵被按下。 onresize視窗或框架被重新調整大小。
onkeypress某個鍵盤按鍵被按下並放開。 onselect文字被選取。
onkeyup某個鍵盤按鍵被放開。 onsubmit確認按鈕被點選。
onunload使用者退出頁面。

键盘鼠标事件:

属性描述
altKey 返回当事件被触发时,"ALT" 是否被按下。
button 返回当事件被触发时,哪个鼠标按钮被点击。
clientX返回当事件被触发时,鼠标指针的水平坐标。
clientY返回当事件被触发时,鼠标指针的垂直坐标。
ctrlKey 返回当事件被触发时,"CTRL" 键是否被按下。
metaKey 返回当事件被触发时,"meta" 键是否被按下。
relatedTarget返回与事件的目标节点相关的节点。
screenX返回当某个事件被触发时,鼠标指针的水平坐标。
screenY 返回当某个事件被触发时,鼠标指针的垂直坐标。
shiftKey 返回当事件被触发时,"SHIFT" 键是否被按下。

小例子:

1、文本框默认文字

<input id="i1" type="text" onfocus="foucs(this)" onblur="blurs(this)" value="请输入关键字"/>
<script>
    function foucs(th){
        var v=th.value;
        if (v==&#39;请输入关键字&#39;){
            th.value=&#39;&#39;;
        }
    }
    function blurs(th){
        var v=th.value;
        if (v.length==0){
            th.value=&#39;请输入关键字&#39;;
            th.style.color="gray";
            th.style.border="1px solid red";
        }
    }</script>
登入後複製

2、添加标签

<div style="border: 1px solid red;" id="std"></div>
function b_b(){
    var std=document.getElementById(&#39;std&#39;);
    var new_b="<input type=&#39;button&#39; value=&#39;我是beforeBegin,在DIV前&#39; />";
    std.insertAdjacentHTML(&#39;beforeBegin&#39;,new_b);}
function a_b(){
    var std=document.getElementById(&#39;std&#39;);
    var new_b="<input type=&#39;button&#39; value=&#39;我是afterBegin,在DIV内前&#39; />";
    std.insertAdjacentHTML(&#39;afterBegin&#39;,new_b);}
function b_e(){
    var std=document.getElementById(&#39;std&#39;);
    var new_b="<input type=&#39;button&#39; value=&#39;我是beforeEnd,在DIV后&#39; />";
    std.insertAdjacentHTML(&#39;beforeEnd&#39;,new_b);}

function a_e(){   
    var std=document.getElementById(&#39;std&#39;);
    var new_b="<input type=&#39;button&#39; value=&#39;我是afterEnd,在DIV内后&#39;/>";
    std.insertAdjacentHTML(&#39;afterEnd&#39;,new_b);}
登入後複製

3、展开同时隐藏其它子菜单:

HTML:

<div id="left_menu" class="left_menu">
    <div id=&#39;m1&#39; class="main_menu" onclick="show_sub_menu(this)"><span>人员管理</span></div>
    <div id=&#39;sm1&#39; class="sub_menu">
        <ul>
            <li>1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
            <li>5</li>
            <li>6</li>
            <li>7</li>
        </ul>
    </div>

    <div  id=&#39;m2&#39; class="main_menu" onclick="show_sub_menu(this)"><span>组别管理</span></div>
    <div id=&#39;sm2&#39; class="sub_menu">
        <ul>
            <li>1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
            <li>5</li>
            <li>6</li>
            <li>7</li>
        </ul>
    </div></div>
登入後複製

js:

function show_sub_menu(th){
    var parentId = th.id;
    var childId=&#39;s&#39;+parentId;
    var childE=document.getElementById(&#39;left_menu&#39;).children;
    for (var s in childE){
        var e=childE[s].classList;
        console.log(e);
        if (e){
            if (childE[s].id==childId){
                childE[s].classList.add(&#39;show&#39;);
            }else{
                childE[s].classList.remove(&#39;show&#39;);
            }
         }
    }}
登入後複製

4、标签提交:

<!-- DOM提交标单!--><form id="f1" action="search.html">
    <input id="input1" type="text"/>
    <a onclick="a_submit()">提交吧</a></form><script>
    function a_submit(){
        document.getElementById(&#39;f1&#39;).submit();
    }</script>
登入後複製

5、html、css、js页面分离:生产环境的写法。

每类存储为单独的文件,其中js使用dom添加事件方法,可以html更简洁。

例子:鼠标移动表格行变色

HTML:

<table id=&#39;tb&#39;>
    <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td></tr>
    <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td></tr>
    <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td></tr>
    <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td></tr>
    <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td></tr></table>
登入後複製

JS:给table添加属性和class

 var t=document.getElementById(&#39;tb&#39;).classList;
    t.add(&#39;tb_style&#39;);
    
    var mytrs=document.getElementsByTagName(&#39;tr&#39;);
    var td_numbers=mytrs.length;
    for (var td=0;td<td_numbers;td++){
        mytrs[td].onmouseover=function(){this.style.backgroundColor=&#39;red&#39;;};
        mytrs[td].onmouseout=function(){this.style.backgroundColor=&#39;&#39;;};
    }
登入後複製

css

.tb_style{
    bacground-color:pink;}
登入後複製

6、词法分析:形参--》函数体内函数,编译时函数体内的函数会分配 内存地址,覆盖形参。

function cifa(age){
    console.log(age);        \\function age
    age=22;
    console.log(age);        \\22
    function age(){};
    console.log(age);        \\22}age(3)
登入後複製

以上是深入學習JavaScript之DOM的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:51cto.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板