4.1 js 配合dom 案例

Posted xuwangqi

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了4.1 js 配合dom 案例相关的知识,希望对你有一定的参考价值。

1.通过点击按钮获取文本框中的信息

视图:

技术图片

代码:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
    <title>如何通过document获取数据</title>
    <meta http-equiv="Content-type" content="text/html; charset=UTF-8" />
    <script type="text/javascript">
        function demo1()
        
        //根据id获取元素
        var username=document.getElementById("username");
        //获取节点对象身上的值
        console.log(username.value);
        
        function demo2()
            
         //根据name获取元素
        var password=document.getElementsByName("password");//这是个数组变量
        //获取每个节点中的值
        for(var i=0;i<password.length;i++)
        console.log(password[i].value);
        
         
         function demo3()
            
         //根据元素名称获取元素
        var input=document.getElementsByTagName("input");
        //获取每个节点中的值
        for(var i=0;i<input.length;i++)
        console.log(input[i].value);
        
         function demo4()
         
             //获取p元素
             var pid=document.getElementById("pid");
             //获取p元素中的文字
             console.log(pid.innerText);//获取P标签中的文字
             //获取p元素中的html内容
             console.log(pid.innerHTML);//<font color="red">获取P标签中的文字</font>
             pid.innerHTML="<font color=‘aqua‘>新的p</font>"
         
             
         
    </script>
    
</head>
<body>

    用户名称:<input type="text" name="username" id="username"/><br />
    用户密码:<input type="password" name="password" id="password" /><br />
    用户密码2:<input type="password" name="password" id="password2" /><br />
    
    <hr />
    <input type="button" value="通过ID获取节点的值" onclick="demo1()"/>
    <input type="button" value="通过NAME获取节点的值"  onclick="demo2()" />
    <input type="button" value="通过TAG获取节点的值" onclick="demo3()" />        
    
    <hr  />
    <p id="pid"><font color="red">获取P标签中的文字</font></p>
    <input type="button" value="获取P中文字" onclick="demo4()" />
    
</body>
</html>

2.节点的增删改查

技术图片

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>节点的增删改查</title>
<!--加入样式表-->
<style type="text/css">
div 
    border:#0099FF 1px solid;
    height:60px;
    width:120px;
    margin:20px 0px 20px 20px;
    padding:10px 0px 0px 20px;
    
    
#div_1
    background-color:#00FFFF;
    
    
#div_2
    background-color:#FF3399;
    
    
#div_3
    background-color:#0000FF;
    
    
#div_4
    background-color:#FFFF66;
    
</style>
<script type="text/javascript">
function addNode()

        //1.创建节点
        var new_div = document.createElement("div");
       //2.挂载节点
       //2.1。寻找一个已有节点(父节点)
      var parent=document.getElementsByTagName("body")[0];
       //2.2将新节点挂在到已有的节点身上(子节点)
       //parent.appendChild(new_div);
       
       //在指定元素之前插入节点
    var div_2=document.getElementById("div_2");
    parent.insertBefore(new_div,div_2);

    function deleteNode()
    
        //删除节点
        //1.找到父节点
        var parent=document.getElementsByTagName("body")[0];
        //2.要删除的子节点
        var div_4=document.getElementById("div_4");
        //3.从父节点上删除子节点
        parent.removeChild(div_4);
    
   function updateNode()
   
       //更新节点
       //1.找到父节点
    var parent=document.getElementsByTagName("body")[0];
       //2.找到要被替换的节点
       var div_3=document.getElementById("div_3");
       //3.创建新的节点---替换旧节点用
       var new_div = document.createElement("div");
    //4.替换旧节点  
    parent.replaceChild(new_div,div_3);
   
   function copyNode()
   
       //克隆节点
       //1.获取目标节点完成克隆
            var div_2=document.getElementById("div_2");
            var copy_div=div_2.cloneNode(true); //true是将元素中的innerText也复制,默认为false
       //2.挂载节点
       //2.1获取父节点
      var parent=document.getElementsByTagName("body")[0];
       
       //2.2挂载节点
       parent.appendChild(copy_div);
       
   
</script>


</head>



<body>
    <div id="div_1">
        
    </div>
    
    <div id="div_2">
    div区域2
    </div>
    
    <div id="div_3">
        div区域3
    </div>
    
    <div id="div_4">
    div区域4
    </div>
    
    <hr />
    <input type="button" value="创建并添加节点" onclick="addNode()" />
    <input type="button" value="删除节点" onclick="deleteNode()" />
    <input type="button" value="替换节点" onclick="updateNode()" />
    <input type="button" value="克隆节点" onclick="copyNode()" />

</body>
</html>

3.字体有变化的新闻广告

技术图片

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>新闻广告</title>
<style type="text/css">
<!-- 伪元素选择器 -->
a:link,a:visited 
    color:#FF9900;
    text-decoration:none;
    font-size:15px;
    
    
a:hover 
    color:#0099FF;
    
    
.newsstyle 
    border:#0099FF 1px solid;
    font-size:16px;
    width:400px;
    
    
/*
预先定一些选择器
*/
.max 
    border:#0099FF 1px solid;
    font-size:20px;
    color:#FF0000;
    background-color:#CCFFFF;
    width:400px;
    
    
.min 
    border:#0099FF 1px solid;
    font-size:12px;
    color:#0000FF;
    background-color:#FFFFFF;
    width:400px;
    

</style>

<script type="text/javascript">
function resize(styleName)
        //获取div节点
        var newstext = document.getElementById("newstext");
        //设置div节点身上的class属性
        newstext.className = styleName;
    
</script>
</head>
<body>
    <h2>这是一个大新闻.</h2>

    <a href="javascript:void(0)" onclick="resize(‘min‘)">小字体</a> 
    <a href="javascript:void(0)" onclick="resize(‘newsstyle‘)">中字体</a> 
    <a href="javascript:void(0)" onclick="resize(‘max‘)">大字体</a> 

    
    <hr />
    
    <div id="newstext" class="newsstyle">
    演示接口.很多内容.怎么办呢?等等<br />
    演示接口.很多内容.怎么办呢?等等<br />
    演示接口.很多内容.怎么办呢?等等<br />
    演示接口.很多内容.怎么办呢?等等<br />
    演示接口.很多内容.怎么办呢?等等<br />
    演示接口.很多内容.怎么办呢?等等<br />
    演示接口.很多内容.怎么办呢?等等<br />
    演示接口.很多内容.怎么办呢?等等<br />
    </div>

</body>
</html>

4.

技术图片

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>好友列表</title>
<style type="text/css">
table 
    border:#0099FF 1px solid;
    width:100px;
    border-collapse:collapse;
    
    
table td
    border:#0066FF 1px solid;
    background-color:#FF9900;
    text-align:center;
    
    
table td div 
    background-color:#FFFF99;
    text-align:left;
    
    
table td a:link, table td a:visited 
    color:#00ffFF;
    text-decoration:none;
    
    
table td a:hover 
    color:#00CC00;
    

/*
使用display属性:如果取值为none就是隐藏标签。
*/
table td div 
    display:none;
    

.open 
    display:block;
    
    
.close 
    display:none;
     

</style>
<script type="text/javascript">
    function openDiv(thisobj)
        //1.点击a标签,将其兄弟div隐藏或显示
        //1.1 thisobj代表的是a标签的对象,根据它找到兄弟div
        //nextSibling拿到的是元素的兄弟元素 而中间可能会夹杂个文档节点(多个空格或换行变一行)所以是两个nextSibling
        var div = thisobj.nextSibling.nextSibling;
        //点击当前div时,其他的div都关闭 
        //获取全部的div 筛选出非点击的div,全部关闭
        var divs = document.getElementsByTagName("div");
        //遍历
        for(var i=0;i<divs.length;i++)
            if(divs[i] != div)
                divs[i].style.display ="none"
            
        
        //2.切换div隐藏或者显示状态
        if(div.style.display == "none")
            
        div.style.display ="block"
        else
            
            div.style.display ="none"
        
        //div.style.display = div.style.display == "none"?"block":"none";
        
    
</script>
<!--
function openDiv(obj)
            //1.获取div
            var div = obj.nextSibling.nextSibling;
            //获取所有的div,如果有开启的div,在另一个div开启后关闭当前div
            var divs =document.getElementsByTagName("div");
            //遍历所有的div,只要不是当前点击的div,就要将其关闭
            for(var i=0;i<divs.length;i++)
                    if(divs[i]!=div)
                        divs[i].style.display = "none";
                    
            
            //2.显示div
            div.style.display = div.style.display == "none"?"block":"none";
            /*if(div.style.display == "none")
                div.style.display = "block";
            else
                div.style.display = "none";
            */
                
            
        

-->

</head>


<body>
<table>
    <tr>
        <td>
            <a href="javascript:void(0)" onclick="openDiv(this)">君王好友</a>
            <div>
                秦始皇<br />
                刘邦<br />
                李世民<br />
                康熙<br />
            </div>
        </td>
    </tr>
    <tr>
        <td>
            <a href="javascript:void(0)" onclick="openDiv(this)">三国好友</a>
            <div>
                刘备<br />
                关羽<br />
                张飞<br />
                赵云<br />
            </div>
        </td>
    </tr>
    <tr>
        <td>
            <a href="javascript:void(0)" onclick="openDiv(this)">美女好友</a>
            <div>
                西施<br />
                貂蝉<br />
                杨贵妃<br />
                王昭君<br />
            </div>
        </td>
    </tr>
    <tr>
        <td>
            <a href="javascript:void(0)" onclick="openDiv(this)">IT好友</a>
            <div>
                马云<br />
                李开复<br />
                俞敏洪<br />
                李彦宏<br />
            </div>
        </td>
    </tr>
</table>
</body>
</html>

5.二级菜单

技术图片

 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>二级联动菜单</title>
<script>
    function selectCity(obj)
        var cities = 
            "北京市":["海淀区","朝阳区","丰台区"],
            "河北省":["石家庄","唐山","秦皇岛"],
            "辽宁省":["沈阳","大连","鞍山"],
            "山东省":["青岛","济南","烟台"]
        
        //1.先获取省市信息
        var provinces=obj.value;
        //2.根据省市信息获取城市信息
        var city=cities[provinces];
        //3.将城市信息绑定在第二个下拉框中
        //3.1获取第二个下拉框
        var sel_city=document.getElementById("city");
        //清空操作
        sel_city.innerHTML="<option>--请选择--</option>"
        //3.2循环添加城市信息
        for(var i=0;i<city.length;i++)
        
            sel_city.innerHTML+="<option>"+ city[i] +"</option>"
        
    
    
        
    
        
</script>
<!--
var cities = 
            "北京市":["海淀区","朝阳区","丰台区"],
            "河北省":["石家庄","唐山","秦皇岛"],
            "辽宁省":["沈阳","大连","鞍山"],
            "山东省":["青岛","济南","烟台"]
        

        //获取对应省市的城市
        var citySelect = cities[obj.value]
        
        //获取第二个select标签对象,并将option进行遍历添加
        var city = document.getElementById("city");
        //在每次添加option之前先清空option
        city.innerHTML = "<option>--请选择--</option>"
    
        for(var i=0;i<citySelect.length;i++)
            var opt = document.createElement("option");
            opt.innerText = citySelect[i];
            city.appendChild(opt);
        
-->
</head>

<!-- 
    "海淀区","朝阳区","丰台区"
    "石家庄","唐山","秦皇岛"
    "沈阳","大连","鞍山"
    "青岛","济南","烟台"
    
-->
<body>
<select id="province" onchange="selectCity(this)">
                                                  <!--
                                                      this 在这里指的是我们改变对象 就是option
                                                  -->
    <option>--选择省市--</option>
    <option>北京市</option>
    <option>河北省</option>
    <option>辽宁省</option>
    <option>山东省</option>
</select>


<select id="city">
    <option>--选择城市--</option>
</select>
</body>

</html>

 

以上是关于4.1 js 配合dom 案例的主要内容,如果未能解决你的问题,请参考以下文章

JS中Dom操作的常用案例实现

js干货-Bom,Dom事件及各种案例

前端案例:飞机大战( js+dom 操作,代码完整)

DOM操作相关案例 模态对话框,简易留言板,js模拟选择器hover,tab选项卡,购物车案例

JS——DOM操作(createElementappendChild的用法,及todolist案例)

[JS DOM&BOM] 排他思想及其案例