黑马程序员技术交流社区

标题: [石家庄校区]JS重点 [打印本页]

作者: 娱乐逗    时间: 2018-12-17 16:17
标题: [石家庄校区]JS重点
[石家庄校区]JS重点



## DOM简单学习:为了满足案例要求
    * 功能:控制html文档的内容
    * 获取页面标签(元素)对象:Element
        * document.getElementById("id值"):通过元素的id获取元素对象
    * 操作Element对象:
        1. 修改属性值:
            1. 明确获取的对象是哪一个?
            2. 查看API文档,找其中有哪些属性可以设置
        2. 修改标签体内容:
            * 属性:innerHTML
            1. 获取元素对象
            2. 使用innerHTML属性修改标签体内容
    * 如何绑定事件
        1. 直接在html标签上,指定事件的属性(操作),属性值就是js代码
            1. 事件:onclick--- 单击事件
        2. 通过js获取元素对象,指定事件属性,设置一个函数
      
[Java] 纯文本查看 复制代码
 * 代码:
            <body>
                <img id="light" src="img/off.gif" >
                <img id="light2" src="img/off.gif">
               
                <script>
                    function fun(){
                        alert('我被点了');
                        alert('我又被点了');
                    }
               
                    function fun2(){
                        alert('咋老点我?');
                    }
               
                    //1.获取light2对象
                    var light2 = document.getElementById("light2");
                    //2.绑定事件
                    light2.onclick = fun2;     
                </script>
            </body>
   
    * 案例1:电灯开关
      
[Java] 纯文本查看 复制代码
 <!DOCTYPE html>
        <html lang="en">
        <head>
            <meta charset="UTF-8">
            <title>电灯开关</title>
        
        </head>
        <body>
        
        <img id="light" src="img/off.gif">
        
        <script>
            /*
                分析:
                    1.获取图片对象
                    2.绑定单击事件
                    3.每次点击切换图片
                        * 规则:
                            * 如果灯是开的 on,切换图片为 off
                            * 如果灯是关的 off,切换图片为 on
                        * 使用标记flag来完成
        
             */
        
            //1.获取图片对象
            var light = document.getElementById("light");
        
            var flag = false;//代表灯是灭的。 off图片
            //2.绑定单击事件
            light.onclick = function(){
                if(flag){//判断如果灯是开的,则灭掉
                    light.src = "img/off.gif";
                    flag = false;
        
                }else{
                    //如果灯是灭的,则打开
        
                    light.src = "img/on.gif";
                    flag = true;
                }
      
            }
        </script>
        </body>
        </html>

# BOM:
    1. 概念:Browser Object Model 浏览器对象模型
        * 将浏览器的各个组成部分封装成对象。


    2. 组成:
        * Window:窗口对象    js中顶级对象
        * Navigator:浏览器对象
        * Screen:显示器屏幕对象
        * History:历史记录对象
        * Location:地址栏对象


    3. Window:窗口对象
        1. 创建
        2. 方法
             1. 与弹出框有关的方法:
                alert()    显示带有一段消息和一个确认按钮的警告框。
                confirm()    显示带有一段消息以及确认按钮和取消按钮的对话框。
                    * 如果用户点击确定按钮,则方法返回true
                    * 如果用户点击取消按钮,则方法返回false
                prompt()    显示可提示用户输入的对话框。
                    * 返回值:获取用户输入的值
             2. 与打开关闭有关的方法:
                close()    关闭浏览器窗口。
                    * 谁调用我 ,我关谁
                open()    打开一个新的浏览器窗口
                    * 返回新的Window对象
             3. 与定时器有关的方式
                setTimeout()    在指定的毫秒数后调用函数或计算表达式。
                    * 参数:
                        1. js代码或者方法对象
                        2. 毫秒值
                    * 返回值:唯一标识,用于取消定时器
                clearTimeout()    取消由 setTimeout() 方法设置的 timeout。
   
                setInterval()    按照指定的周期(以毫秒计)来调用函数或计算表达式。
                clearInterval()    取消由 setInterval() 设置的 timeout。
   
        3. 属性:
            1. 获取其他BOM对象:
                history
                location
                Navigator
                Screen:
            2. 获取DOM对象
                document
        4. 特点
            * Window对象不需要创建可以直接使用 window使用。 window.方法名();
            * window引用可以省略。  方法名();

    4. Location:地址栏对象
        1. 创建(获取):
            1. window.location
            2. location


        2. 方法:
            * reload()    重新加载当前文档。刷新
        3. 属性
            * href    设置或返回完整的 URL。


    5. History:历史记录对象
        1. 创建(获取):
            1. window.history
            2. history


        2. 方法:
            * back()    加载 history 列表中的前一个 URL。
            * forward()    加载 history 列表中的下一个 URL。
            * go(参数)    加载 history 列表中的某个具体页面。
                * 参数:
                    * 正数:前进几个历史记录
                    * 负数:后退几个历史记录
        3. 属性:
            * length    返回当前窗口历史列表中的 URL 数量。

## DOM:
    * 概念: Document Object Model 文档对象模型
        * 将标记语言文档的各个组成部分,封装为对象。可以使用这些对象,对标记语言文档进行CRUD的动态操作
    * W3C DOM 标准被分为 3 个不同的部分:
        * 核心 DOM - 针对任何结构化文档的标准模型
            * Document:文档对象   -->整个html文档对象
            * Element:元素对象    -->标签
            * Attribute:属性对象  -->标签的属性
            * Text:文本对象       -->标签的内容
            * Comment:注释对象


            * Node:节点对象,其他5个的父对象
        * XML DOM - 针对 XML 文档的标准模型
        * HTML DOM - 针对 HTML 文档的标准模型

    * 核心DOM模型:
        * Document:文档对象
            1. 创建(获取):在html dom模型中可以使用window对象来获取
                1. window.document
                2. document
            2. 方法:
                1. 获取Element对象:
                    1. getElementById()    : 根据id属性值获取元素对象。id属性值一般唯一
                    2. getElementsByTagName():根据元素名称获取元素对象们。返回值是一个数组
                    3. getElementsByClassName():根据Class属性值获取元素对象们。返回值是一个数组
                    4. getElementsByName(): 根据name属性值获取元素对象们。返回值是一个数组
                2. 创建其他DOM对象:
                    createAttribute(name)
                    createComment()
                    createElement()**  -->创建标签
                    createTextNode()   -->文本节点
            3. 属性
        * Element:元素对象
            1. 获取/创建:通过document来获取和创建
            2. 方法:
                1. removeAttribute():删除属性
                2. setAttribute():设置属性
        * Node:节点对象,其他5个的父对象
            * 特点:所有dom对象都可以被认为是一个节点
            * 方法:
                * CRUD dom树:
                    * appendChild(标签对象/文本节点对象):向节点的子节点列表的结尾添加新的子节点。
                    * removeChild(标签)    :删除(并返回)当前节点的指定子节点。
                    * replaceChild():用新节点替换一个子节点。
            * 属性:
                * parentNode 返回节点的父节点。
   
    ps超链接功能:
        1,可以被点击:样式,
        2,点击后跳转到href制定的url
            href ="javascript : void(0);" 这个链接指点击后无操作
    ##js中如何输出日志
        console.log("日志")
    ##js如何进行debug
        在感觉出问题的地方添加 debugger


    * HTML DOM
        1. 标签体的设置和获取:innerHTML
        2. 使用html元素对象的属性
        3. 控制元素样式
            1. 使用元素的style属性来设置
                如:
                     //修改样式方式1
                    div1.style.border = "1px solid red";
                    div1.style.width = "200px";
                    //font-size--> fontSize
                    div1.style.fontSize = "20px";
            2. 提前定义好类选择器的样式,通过元素的className属性来设置其class属性值。




## 事件监听机制:
    * 概念:某些组件被执行了某些操作后,触发某些代码的执行。   
        * 事件:某些操作。如: 单击,双击,键盘按下了,鼠标移动了
        * 事件源:组件。如: 按钮 文本输入框...
        * 监听器:代码。
        * 注册监听:将事件,事件源,监听器结合在一起。 当事件源上发生了某个事件,则触发执行某个监听器代码。




    * 常见的事件:
        1. 点击事件:
            1. onclick:单击事件
            2. ondblclick:双击事件
        2. 焦点事件
            1. onblur:失去焦点
            2. onfocus:元素获得焦点。


        3. 加载事件:
            1. onload:一张页面或一幅图像完成加载。


        4. 鼠标事件:
            1. onmousedown    鼠标按钮被按下。
            2. onmouseup    鼠标按键被松开。
            3. onmousemove    鼠标被移动。
            4. onmouseover    鼠标移到某元素之上。
            5. onmouseout    鼠标从某元素移开。
            
            
        5. 键盘事件:
            1. onkeydown    某个键盘按键被按下。   
            2. onkeyup        某个键盘按键被松开。
            3. onkeypress    某个键盘按键被按下并松开。


        6. 选择和改变
            1. onchange    域的内容被改变。
            2. onselect    文本被选中。


        7. 表单事件:
            1. onsubmit    确认按钮被点击。
            2. onreset    重置按钮被点击


*************99乘法表案例
[Java] 纯文本查看 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>99乘法表</title>
    <style>
        td{
            border:1px solid;

        }
        tr{
            background: gold;
        }
    </style>
    <script>
        document.write("<table align='center'>")
        for(var i=1;i<=9;i++){
            document.write("<tr>")
            for(j=1;j<=i;j++){
                document.write("<td>")
                document.write(i+"*"+j +"="+(i*j))
                document.write("</td>")
            }
            document.write("</tr>")
        }
        document.write("</table>")
    </script>

</head>
<body>

</body>
</html>

****************轮播图案例  图片按格式自行加载
[Java] 纯文本查看 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>轮播图</title>

</head>
<body>

    <img src="img/banner_1.jpg" id="tu" width="100%">;

    <script>
        var tu = document.getElementById("tu");
        var number = 1;
        function fun() {
            number ++;
            if(number>3){
                number =1 ;
            }
            tu.src="img/banner_"+number+".jpg";
        }

        setInterval(fun,2000);
    </script>

</body>
</html>

******************表单提交事件
[Java] 纯文本查看 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>注册页面</title>
    <style>
        /*整体页面*/
        body {
            background: url("img/register_bg.png") no-repeat center;
            padding:25px;
            padding-left: 300px;
        }
        /*注册页面*/
        .d1{
            border: 5px solid darkgray;
            width: 700px;
            height: 500px;
            background: beige;
            padding-left: 15px;
        }
        /*右上角内容*/
        .d2{
            /*border: 2px solid red;*/
            float: left;
        }
        #p1{
            font-size: 20px;
            color: gold;
        }
        #p2{
            font-size: 20px;
            color: darkgray;
            line-height: 0px;
        }
        /*中间内容*/
        .d3{
            float: left;
            /*border: 2px solid red;*/
            margin-top: 20px;
        }
        .td{
            text-align: right;
            line-height: 50px;
            padding-left: 50px;
            padding-right: 10px;
        }
        #username,#password,#name,#email,#brithdaty,#tel{
            padding-left: 10px;
            border-radius: 5px;
            /*border: darkgray 1px solid;*/
            width: 200px;
            height: 30px;

        }
        #yan{
            width: 100px;
            padding-left: 10px;
            border-radius: 5px;
            /*border: darkgray 1px solid;*/
            height: 30px;
        }
        .ti{
            background: gold;
            width: 60px;
            height: 30px;
        }
        #td_su{
            padding-left: 150px;
        }
        .tu{
            width: 70px;
            height: 30px;
        }
        .d4{
            float: right;
            /*border: 1px solid red;*/
            margin-right: 15px;
            margin-top: 18px;
        }
        .a1{
            color: pink;
        }
    </style>

    <script>
        window.onload=function () {
            document.getElementById("form").onsubmit=function () {
                return checkUsername() && checkPassword() && checkTel();
            }
            document.getElementById("username").onblur=checkUsername;
            document.getElementById("password").onblur=checkPassword;
            document.getElementById("tel").onblur=checkTel;
            function checkUsername() {
                var username = document.getElementById("username").value;
                var r_un = /^\w{6,12}$/;
                var flag = r_un.test(username);
                var sun = document.getElementById("un");
                    if(flag){
                        sun.innerHTML ="<img src='img/gou.png' height='25' width='35'>";
                    } else {
                        sun.innerHTML = "用户名格式有误";
                    }
                    return flag;
            }
            function checkPassword() {
                var password = document.getElementById("password").value;
                var r_pw = /^\w{6,12}$/;
                var flag = r_pw.test(password);
                var spw = document.getElementById("pw");
                if(flag){
                    spw.innerHTML ="<img src='img/gou.png' height='25' width='35'>";
                } else {
                    spw.innerHTML = "密码格式有误";
                }
                return flag;
            }
            function checkTel() {
                var tel = document.getElementById("tel").value;
                var r_nu = /^\d{11,11}$/;
                var flag = r_nu.test(tel);
                var snu = document.getElementById("nu");
                if(flag){
                    snu.innerHTML ="<img src='img/gou.png' height='25' width='35'>";
                } else {
                    snu.innerHTML = "密码格式有误";
                }
                return flag;
            }
        }

    </script>


</head>
<body>
    <div class="d1">
        <div class="d2">
            <p id="p1">新用户注册</p>
            <p id="p2">USER REGISTER</p>
        </div>
        <div class="d3">
            <form action="#" method="post" id="form">
                <table>
                    <tr>
                        <td class="td"><label for="username">用户名</label></td>
                        <td><input type="text" name="username" id="username" placeholder="请输入用户名">
                        <span id="un" class="error"></span>
                        </td>
                    </tr>
                    <tr>
                        <td class="td"><label for="password">密码</label></td>
                        <td><input type="password" name="password" id="password" placeholder="请输入用密码">
                        <span id="pw" class="error"></span>
                        </td>
                    </tr>
                    <tr>
                        <td class="td"><label for="email">Email</label></td>
                        <td><input type="email" name="email" id="email" placeholder="请输入Email"></td>
                    </tr>
                    <tr>
                        <td class="td"><label for="name">姓名</label></td>
                        <td><input type="text" name="name" id="name" placeholder="请输入真实姓名"></td>
                    </tr>
                    <tr>
                        <td class="td"><label for="tel">手机号</label></td>
                        <td><input type="number" name="tel" id="tel" placeholder="请输入手机号">
                            <span id="nu" class="error"></span>
                        </td>
                    </tr>
                    <tr>
                        <td class="td">性别</td>
                        <td><input type="radio" name="gender" value="man"> 男
                            <input type="radio" name="gender" value="women"> 女
                        </td>
                    </tr>
                    <tr>
                        <td class="td" for="brithdaty">出生日期</td>
                        <td><input type="date" name="brithdaty" id="brithdaty"></td>
                    </tr>
                    <tr>
                        <td class="td">验证码</td>
                        <td><input type="text" name="code" id="yan"> <img src="img/verify_code.jpg" alt="" class="tu"></td>
                    </tr>
                    <tr>
                        <td colspan="2" id="td_su"><input type="submit" value="注册" class="ti">
                        </td>
                    </tr>

                </table>
            </form>

        </div>
        <div class="d4">
            已有账号?<a href="./旅游网.html" target="_blank" class="a1"> 立即登录</a>
        </div>
    </div>
</body>
</html>

**********************动态表格案例
[Java] 纯文本查看 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>动态表格</title>

    <style>
        table{
            border: 1px solid;
            margin: auto;
            width: 500px;
        }

        td,th{
            text-align: center;
            border: 1px solid;
        }
        div{
            text-align: center;
            margin: 50px;
        }
    </style>

</head>
<body>

    <div>
        <input type="text" id="id" placeholder="请输入编号">
        <input type="text" id="name"  placeholder="请输入姓名">
        <input type="text" id="gender"  placeholder="请输入性别">
        <input type="button" value="添加" id="btn_add">

    </div>


    <table id="table">
        <caption>学生信息表</caption>
        <tr>
            <th>编号</th>
            <th>姓名</th>
            <th>性别</th>
            <th>操作</th>
        </tr>

        <tr>
            <td>1</td>
            <td>令狐冲</td>
            <td>男</td>
            <td><a href="javascript:void(0)">删除</a></td>
        </tr>

        <tr>
            <td>2</td>
            <td>任我行</td>
            <td>男</td>
            <td><a href="javascript:void(0)">删除</a></td>
        </tr>

        <tr>
            <td>3</td>
            <td>岳不群</td>
            <td>?</td>
            <td><a href="javascript:void(0)">删除</a></td>
        </tr>
    </table>

    <script>
        //添加表格方法一
        var btn_add = document.getElementById("btn_add");
        btn_add.onclick=function () {
            var id = document.getElementById("id").value;
            var name = document.getElementById("name").value;
            var gender = document.getElementById("gender").value;
            var table = document.getElementById("table");

            var tr = document.createElement("tr");
            var td_id = document.createElement("td");
            var text_id = document.createTextNode(id);
            td_id.appendChild(text_id);
            tr.appendChild(td_id)

            var td_name = document.createElement("td");
            var text_name = document.createTextNode(name);
            td_name.appendChild(text_name);
            tr.appendChild(td_name)

            var td_gender = document.createElement("td");
            var text_gender = document.createTextNode(gender);
            td_gender.appendChild(text_gender);
            tr.appendChild(td_gender)

            var td_c = document.createElement("td");
            var a = document.createElement("a");
            a.setAttribute("href","javascript:void(0)");
            a.setAttribute("onclick","delTr(this);");
            var text_a = document.createTextNode("删除");
            a.appendChild(text_a);
            td_c.appendChild(a);
            tr.appendChild(td_c);

            table.appendChild(tr);
        }
        //添加表格方法二
        var btn_add = document.getElementById("btn_add");
        btn_add.onclick=function () {
            var id = document.getElementById("id").value;
            var name = document.getElementById("name").value;
            var gender = document.getElementById("gender").value;
            var table = document.getElementById("table");

            table.innerHTML+="<tr>\n" +
                "            <td>"+id+"</td>\n" +
                "            <td>"+name+"</td>\n" +
                "            <td>"+gender+"</td>\n" +
                "            <td><a href=\"javascript:void(0)\" onclick=\"delTr(this);\">删除</a></td>\n" +
                "        </tr>";
        }

        ////删除表格
        function delTr(obj) {
            var table = obj.parentNode.parentNode.parentNode;
            var tr = obj.parentNode.parentNode;
            table.removeChild(tr);
        }
    </script>
</body>
</html>









欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2