zoukankan      html  css  js  c++  java
  • js导读,js引入,js选择器,事件,操作页面文档,计算后样式,数据类型

    js导读

    '''
    js属于编写运行在浏览器上的脚本语言(相当于具有逻辑的代码)

    一个完整的JavaScript实现应该由以下三部分组成:1)ECMAScript:核心 2)DOM:文档对象模型 3)BOM:浏览器对象模型
    js采用ECMAScript语法
    操作BOM:浏览器对象模型 eg:浏览器上下滑动,浏览器历史记录
    操作DOM:文档对象模型
    '''

    js引入

    <style>
        #box, #wrap, #temp, #res {
             200px;
            height: 200px;
            background-color: red;
            margin-top: 10px;
        }
    </style>
    <!--1.行间式: js代码块也就是脚本书写在事件的全局属性中-->
    <!--this就是激活该代码块(脚本)的页面标签(页面元素对象)-->
    <div id="box" onclick="this.style.borderRadius = '10px'"></div>
    <div id="wrap" onclick="this.style.backgroundColor = 'orange'"></div>
    
    <!--2.内联式-->
    <div id="temp"></div>
    <!--操作写在下面-->
    <script>
        // id为标签的唯一标识, 使用可以识别到html中的具体标签
        temp.onclick = function () { // 完成某一项功能
            this.style.width = "400px";  // this => temp
        }
    </script>
    
    <!--3.外联式-->
    <div id="res"></div>
    <script src="js/1.js">
    // js/1.js
    res.onclick = function () {  // res点击会触发一个功能
        this.style.height = "100px";  // this => res
        this.style.backgroundColor = "yellow";
        this.style.borderRadius = "50%";
    <script></script> 写在 </body></html>之间

    js选择器

    <body>
        <div id="box"></div>
        <div id="box"></div>
    </body>
    <script>
        box.onclick = function () {
          this.style.borderRadius = "50%";
        }
    </script>
    //上述结果一个都匹配不到
    //注意:虽然id可以重复,但是js中却无法唯一标识识别,为了可以唯一标识识别,我们要确保标签id名的唯一性
    
    // document对象 文档对象:整个页面中的所有对象,通过document可以获取文档中的所有对象
    //getElement系列选择器
    <body> <div id="box"></div> <div id="box"></div> </body> <script> document.getElementById('box').onclick = function () { this.style.borderRadius = "50%"; } </script> // 上述操作能获得到第一个id="box", 但是第二个永远取不到, 所以id还是不能重复 js中如何定义变量名?
    关键字 变量名 = 变量值 var num
    = 10; 如何查看变量名? 不能用print(num),这个操作是调用浏览器使用打印机 ①弹出框查看 alert(num) ②浏览器控制台查看 console.log(num); ③将内容书写在页面中 document.write(num); ④断点调试 ②④使用的比较多 <div id='box'></div> <div id='box'></div> <div class='box1'></div> <div class='box1'></div> <div class="box2">1</div> <div class="box2">2</div> <script> // getElement系列 //①通过id查找 // box 获取的是第一个box var box = document.getElementById('box'); console.log(box) #结果:<div id='box'></div> box.onclick = function () { this.style.backgroundColor = "red"; } //②通过类名查找=>类名可以重复,获取结果是数组(列表) // [] | [.box1] | [.box1, ..., .box1] var boxs = document.getElementsByClassName('box1'); console.log(boxs) #结果:[div.box1, div.box1] boxs[0].onclick = function () { this.style.backgroundColor = "pink"; } boxs[1].onclick = function () { this.style.backgroundColor = "black"; } //③通过标签名查找=>标签名=>获取结果数组(列表) // [] | [div] | [div, ..., div] var divs = document.getElementsByTagName('div'); console.log(divs) #结果:[div#box, div#box, div.box1, div.box1, div.box2, div.box2, box: div#box] divs[1].onclick = function () { this.style.borderRadius = "50%"; } // 总结: 参数采用的是id名或类名或标签名,不需要带符号(#|.) </script> <script> // 只能获取检索到的第一个满足条件的标签(元素对象) var box2 = document.querySelector('body .box2'); console.log(box2) box1.onclick = function () { this.style.borderRadius = "50%"; } // 获取的是所有满足条件的标签 var boxes = document.querySelectorAll('body .box2'); console.log(boxes) boxes[0].onclick = function () { this.style.backgroundColor = "pink"; } boxes[1].onclick = function () { this.style.backgroundColor = "black"; } // 总结: 参数采用的就是css选择器语法 </script>

    事件

    var box = document.querySelector('.box');
    
    // 元素对象.事件名 = 函数
    box.onclick = function() {
        // 具体功能代码块; this代表就是激活该事件的元素对象
        this.style.color = 'red'; // 将box的字体颜色修改为红色
    }

    操作页面文档

    // 1. 通过选择器获取页面元素对象(指定的标签)
    // 2. 为该对象绑定事件
    // 3. 通过事件中的功能操作元素对象
    // i) 修改内容: innerText | innerHTML
    // ii) 修改样式
    // iii) 修改类名
    
    var box = document.querySelector('.box'); // 获取页面元素
    box.onclick = function () {  // 绑定事件
        // 修改内容
        // this.innerText = "innerText";  // 不能解析html标签
        // this.innerHTML = "<i>innerHTML</i>";  // 可以解析html标签
    
        // 修改样式 => 修改的是行间式 => 优先级高于所有内联外联样式(没有设置!important前提下)
        // this.style.color = "green";
        // this.style.fontSize = "12px";
    
        // 修改类名
        // this.className = "box1";  // 直接修改类名, 会丢失之前类名下的属性们
        // 在原类名基础上添加类型
        this.className += " box1"; // 多类名之间用空格隔开, 所有做字符串拼接时一定需要添加空格
        // 清除类名
        this.className = "";  // 将类名等于空字符串就是置空类名
    }

    计算后样式

    //什么是计算后样式?内联式和外联式书写的样式都是计算后样式
    
    // 如何获取提取设置好的样式属性值
    var box = document.querySelector('.box');
    var ftSize = box.style.fontSize;  // 这种方式操作的永远是行间式
    console.log(">>>>>>>>>>>>>>>>" + ftSize);
    
    // 内联或外联设置(getComputedStyle也能获取到行间式的设置)
    .box {
        font-size: 100px;
    }
    // 如何获取计算后样式
    // getComputedStyle(元素对象, 伪类).属性名
    var box = document.querySelector('.box');
    var ftSize = getComputedStyle(box, null).fontSize;
    console.log(ftSize);  // 100px

    数据类型

    // 1.定义变量
    var num = 10;
    var s = "hello js";
    console.log(num, "<<>>", s);
    console.log("%d  %s", num, s);
    // 将字符串赋值给页面元素对象,直接在页面上打印
    box.innerText = s;
    
    //命名规范:
    // 由字母,数字,_,$组成,不能以数字开头(可以包含中文字符)
    // 区分大小写
    // 不能出现关键字及保留字
    // var var = 30;  // 出错

    值类型

    // Number: 数字类型
    var a1 = 10;
    var a2 = 3.14
    
    // String: 字符串
    var s1 = "123";
    var s2 = '456';
    
    // undefined: 未定义
    var u1;
    var u2 = undefined;
    
    // Boolean: 布尔
    var b1 = true;
    var b2 = false;
    
    // typeof() 来查看数据类型
    eg:console.log(a1,typeof(a1));
    
    注意:js不直接操作内存

    引用类型

    // Object:对象类型=>可以当做字典来使用
    var obj = {};
    
    // Function:函数类型
    var func = function(){}
    
    // Null =>空对象
    var n = null;

    常用对象类型

    // 数组
    a = new Array(1, 2, 3, 4, 5);
    a = [5, 4, 3, 2, 1];  // 语法糖
    
    // 时间对象
    var a = new Date();//当前时间
    // a = new Date("2019-3-1 12:00:00");  // 设定的时间
    console.log(a.getFullYear());//年
    console.log(a.getDay()); // 周几
    console.log(a.getMonth()); // 月份(从0开始)
    console.log(a.getDate()); // 几号
    // 浏览器cookie 需要前后台交互,存储临时状态 如:过期时间,七天免登陆
    
    //正则
    re = /d{2}/g;
    res = 'a1b23c456'.match(re);
    console.log(res);
    结果:(2) ["23", "45"]
    
    re =/[abc]/gi; //a或b或c
    res = 'aBc'.match(re);
    console.log(res);
    结果:(3) ["a", "B", "c"]
    // 总结:
    // 1.正则 /正则语法/
    // 2.参数g 全文匹配
    // 3.参数i 不区分大小写

    数组与对象(字典)的使用

    var arr = [3,5,2,1,4];
    console.log(arr[1]);
    
    var dic = {'name':'henry','age':18,'little-name':'zz'};
    console.log(dic['name']);
    console.log(dic['age']);
    console.log(dic.name);
    console.log(dic.age);
    console.log(dic['little-name']);
    // dic中所有的key都是string类型, value可以为任意类型
    // dic中key可以通过中括号及 .语法访问值,当key不满足js命名规范时,只能使用中括号语法
  • 相关阅读:
    在SSM框架中,multfile转file
    mysql 存储过程简单实例
    mysql 对比两个表的一致性
    Lucene 排序 Sort与SortField
    Lucene5.x 中文 同义词
    Lucene分页-----SearcherAfter
    Lucene的Query类介绍
    二叉树实例学习(四)——获取节点的高度函数getHight()
    二叉树实例学习(三)——插入左右节点函数测试
    二叉树实例学习(二)
  • 原文地址:https://www.cnblogs.com/lizeqian1994/p/10307136.html
Copyright © 2011-2022 走看看