• JavaScript 笔记总结


    一、js的简介 
    1、js是什么
      js是可以嵌入到html中,是 基于对象 和 事件驱动 的 脚本语言
      特点:
        (1)交互性
        (2)安全性:js不能访问本地磁盘
        (3)跨平台:浏览器中都具备js解析器
    2、js能做什么
       (1)js能动态的修改(增删)html和css的代码
       (2)能动态的校验数据

    3、js历史及组成
      ECMAScript BOM(浏览器对象模型)  DOM(文档对象模型)
    4、js被引入的方式
      (1)内嵌脚本
        <input type="button" value="button" onclick="alert('xxx')" />
      (2)内部脚本
        <script type="text/javascript">
          alert("xxx");
        </script>
    (3)外部脚本
      首先先创建一个js文件
      其次在html中引入
      <script type="text/javascript" src="demo1.js"></script>
      js代码放在哪?
        放在哪都行 但是在不影响html功能的前提下 越晚加载越好
    二、js基本语法
    1、变量
      (1)
        var x = 5;
        x = 'javascript';
        var y = "hello";
        var b = true;
      (2)
        x = 5;

    2、原始数据类型
      (1)number:数字类型
      (2)string:字符串类型
      (3)boolean:布尔类型
      (4)null:空类型
      (5)underfind:未定义

      注意:number、boolean、string是伪对象

      类型转换:
        numberoolean转成string
        toString();
        stringoolean转成number
        parseInt()
        parseFloat()
        boolean 不能转
        string 可以将数字字符串转换成number 如果“123a3sd5” 转成123强制转换
        Boolean()  强转成布尔
        数字强转成布尔  非零就是true   零就是false
        字符串强转成布尔  非“”(空字符串)就是true   空字符串“”就是false
        Number() 强转成数字
        布尔转数字 true转成1  false转成0
        字符串转数字 不能强转

    3、引用数据类型
      java: Object obj = new Object();
      js: var obj = new Object();
      var num = new Number();

    4、运算符
      (1)赋值运算符
        var x = 5;
      (2)算数运算符
        + - * / %
        +: 遇到字符串变成连接
        -:先把字符串转成数字然后进行运算
        *: 先把字符串转成数字然后进行运算
        /: 先把字符串转成数字然后进行运算
      (3)逻辑运算符
        && ||
      (4)比较运算符
        < > >= <= != ==
        ===:全等:类型与值都要相等
      (5)三元运算符
        3<2?"大于":"小于"
      (6)void运算符
        <a href="javascript:void(0);">xxxxxx</a>
      (7)类型运算符
        typeof:判断数据类型 返回我的数据类型
        instanceof:判断数据类型 是否是某种类型
        var obj = new Object();
        alert(typeof obj);//object
        alert(obj instanceof Object);//true
    5、逻辑语句
      (1)if-else
        //条件:
        //数字非0 字符串非空====true
        if(9){
          alert("true--");
        }else{
          alert("false--");
        }
      (2)switch
        var x = "java";
        switch(x){
          case "css":
            alert("css");
            break;
          case "js":
            alert("js");
            break;
          case "java":
            alert("java");
            break;
          default:
            alert("def");
          }

      (3)for
         for(var i = 0;i<5;i++){
          alert(i);
         }
      (4)for in
        var arr = [1,3,5,7,"js"];
         for(index in arr){//index代表角标
          //alert(index);
          alert(arr[index]);
         }

    三、js内建对象
      (1)Number
        创建方式:
          var myNum=new Number(value);
          var myNum=Number(value);
          属性和方法:
            toString():转成字符串
            valueOf():返回一个 Number 对象的基本数字值
      (2)Boolean
        创建方式:
          var bool = new Boolean(value);
          var bool = Boolean(value);
        属性和方法:
          toString():转成字符串
          valueOf():返回一个 Boolean 对象的基本值(boolean)
      (3)String
        创建方式:
          var str = new String(s);
          var str = String(s);
        属性和方法:
          length:字符串的长度
          charAt():返回索引字符
          charCodeAt:返回索引字符unicode
          indexOf():返回字符的索引
          lastIndexOf();逆向返回字符的索引
          split();将字符串按照特殊字符切割成数组
          substr():从起始索引号提取字符串中指定数目的字符
          substring():提取字符串中两个指定的索引号之间的字符
          toUpperCase();转大写
      (4)Array
        创建方式:
          var arr = new Array();//空数组
          var arr = new Array(size);//创建一个指定长度的数据
          var arr = new Array(element0, element1, ..., elementn);//创建数组直接实例化元素
          var arr = [];//空数组
          var arr = [1,2,5,"java"];//创建数组直接实例化元素
        属性和方法:
          length:数组长度
          join():把数组的所有元素放入一个字符串。元素通过指定的分隔符进行分隔一个
          pop():删除并返回最后元素
          push():向数组的末尾添加一个或更多元素,并返回新的长度
          reverse();反转数组
          sort();排序
      (5)Date
        创建方式:
          var myDate = new Date();
          var myDate = new Date(毫秒值);//代表从1970-1-1到现在的一个毫秒值
        属性和方法
          getFullYear():年
          getMonth():月 0-11
          getDate():日 1-31
          getDay():星期 0-6
          getTime():返回1970年1月1日午夜到指定日期(字符串)的毫秒数
          toLocalString();获得本地时间格式的字符串
      (6)Math
        创建方式:
          Math 对象并不像 Date 和 String 那样是对象的类,因此没有构造函数 Math(),像 Math.sin() 这样的函数只是函数,不是某个对象的方法。您无需创建它,通过把 Math 作为对象使用就可以调用其所有属性和方法。
        属性和方法
          PI:圆周率
          abs():绝对值
          ceil():对数进行上舍入
          floor():对数进行下舍入
          pow(x,y):返回 x 的 y 次幂
          random():0-1之间的随机数
          round():四舍五入
      (7)RegExp
        创建方式:
          var reg = new RegExp(pattern);
          var reg = /^正则规则$/;
        规则的写法:
          [0-9] 
          [A-Z]
          [a-z]
          [A-z]
          d 代表数据
          D 非数字
          w 查找单词字符
          W 查找非单词字符
          s 查找空白字符
          S 查找非空白字符
          n+ 出现至少一次
          n* 出现0次或多次
          n? 出现0次或1次
          {5} 出现5
          {2,8} 2到8次
        方法:
          test(str):检索字符串中指定的值。返回 true 或 false
        需求:
          校验邮箱:
            var email = haohao_827@163.com
            var reg = /^[A-z]+[A-z0-9_-]*@[A-z0-9]+.[A-z]+$/;
            reg.test(email);
    四、js的函数
    1、js函数定义的方式
      (1)普通方式
        语法:function 函数名(参数列表){函数体}
        示例:
          function method(){
            alert("xxx");
          }
          method();
      (2)匿名函数
        语法:function(参数列表){函数体}
        示例:
          var method = function(){
            alert("yyy");
          };
          method();
      (3)对象函数
        语法:new Function(参数1,参数2,...,函数体);
        注意:参数名称必须使用字符串形式、最后一个默认是函数体且函数体需要字符串形式
        示例:
          var fn = new Function("a","b","alert(a+b)");
          fn(2,5);
    2、函数的参数
      (1)形参没有var去修饰
      (2)形参和实参个数不一定相等
      (3)arguments对象 是个数组 会将传递的实参进行封装
        function fn(a,b,c){
          //var sum = a+b+c;
          //alert(sum);
          //arguments是个数组 会将传递的实参进行封装
          for(var i=0;i<arguments.length;i++){
            alert(arguments[i]);
          }
        }
        fn(1,2,4,8);

    3、返回值
      (1)在定义函数的时候不必表明是否具有返回值
      (2)返回值仅仅通过return关键字就可以了 return后的代码不执行
        function fn(a,b){
          return a+b;
          //alert("xxxx");
        }
        alert(fn(2,3));

    4、js的全局函数
      (1)编码和解码
        encodeURI()   decodeURI()
        encodeURIComponet()   decodeURIComponent()
        escape() unescape()
        三者区别:
          进行编码的符号范围不同吧,实际开发中常使用第一种
      (2)强制转换
        Number()
        String()
        Boolean()
      (3)转成数字
        parseInt()
        parseFloat()
      (4)eval()方法
        将字符串当作脚本进行解析运行
        //var str = "var a=2;var b=3;alert(a+b)";
        //eval(str);
        function print(str){
          eval(str);
        }
        print("自定义逻辑");

    五、js的事件
      事件
      事件源
      响应行为
    1、js的常用事件
      onclick:点击事件
      onchange:域内容被改变的事件
      需求:实现二级联动
        <select id="city">
          <option value="bj">北京</option>
          <option value="tj">天津</option>
          <option value="sh">上海</option>
        </select>
        <select id="area">
          <option>海淀</option>
          <option>朝阳</option>
          <option>东城</option>
        </select>
        <script type="text/javascript">
        var select = document.getElementById("city");
        select.onchange = function(){
          var optionVal = select.value;
          switch(optionVal){
            case 'bj':
              var area = document.getElementById("area");

              area.innerHTML = "<option>海淀</option><option>朝阳</option><option>东城</option>";    

                                   break;

            case 'tj':
              var area = document.getElementById("area");
              area.innerHTML = "<option>南开</option><option>西青</option><option>河西</option>";
              break;
            case 'sh':
              var area = document.getElementById("area");
              area.innerHTML = "<option>浦东</option><option>杨浦</option>";
              break;
            default:
              alert("error");
          }
        };
        </script>
    onfoucus:获得焦点的事件
    onblur:失去焦点的事件
    需求: 当输入框获得焦点的时候,提示输入的内容格式
    当输入框失去焦点的时候,提示输入有误
    <label for="txt">name</label>
    <input id="txt" type="text" /><span id="action"></span>
    <script type="text/javascript">
    var txt = document.getElementById("txt");
    txt.onfocus = function(){
    //友好提示
    var span = document.getElementById("action");
    span.innerHTML = "用户名格式最小8位";
    span.style.color = "green";
    };
    txt.onblur = function(){
    //错误提示
    var span = document.getElementById("action");
    span.innerHTML = "对不起 格式不正确";
    span.style.color = "red";
    };
    </script>

    onmouseover:鼠标悬浮的事件
    onmouseout:鼠标离开的事件
    需求:div元素 鼠标移入变为绿色 移出恢复原色
    #d1{200px;height: 200px;}
    <div id="d1"></div>
    <script type="text/javascript">
    var div = document.getElementById("d1");
    div.onmouseover = function(){
    this.style.backgroundColor = "green";
    };
    div.onmouseout = function(){
    this.style.backgroundColor = "red";
    };
    </script>


    onload:加载完毕的事件
    等到页面加载完毕在执行onload事件所指向的函数
    <span id="span"></span>
    <script type="text/javascript">
    window.onload = function(){
    var span = document.getElementById("span");
    alert(span);
    span.innerHTML = "hello js";
    };
    </script>

    2、事件的绑定方式
    (1)将事件和响应行为都内嵌到html标签中
    <input type="button" value="button"  onclick="alert('xxx')"/>
    (2)将事件内嵌到html中而响应行为用函数进行封装
    <input type="button" value="button" onclick="fn()" />
    <script type="text/javascript">
    function fn(){
    alert("yyy");
    }
    </script>
    (3)将事件和响应行为 与html标签完全分离
    <input id="btn" type="button" value="button"/>
    <script type="text/javascript">
    var btn = document.getElementById("btn");
    btn.onclick = function(){
    alert("zzz");
    };
    </script>

    ****this关键字
    this经过事件的函数进行传递的是html标签对象
    <input id="btn" name="mybtn" type="button" value="button123" onclick="fn(this)"/>
    <script type="text/javascript">
    function fn(obj){
    alert(obj.name);
    }
    </script>

    3、阻止事件的默认行为
    IE:window.event.returnValue = false;
    W3c: 传递过来的事件对象.preventDefault();
    //ie:window.event.returnValue = false;
    //W3c:传递过来的事件对象.preventDefault();
    //W3c标准
    if(e&&e.preventDefault){
    alert("w3c");
    e.preventDefault();
    //IE标签
    }else{
    alert("ie");
    window.event.returnValue = false;
    }


    //通过事件返回false也可以阻止事件的默认行为
    <a href="demo11.html" onclick="return false">点击我吧</a>

    4、阻止事件的传播
    IE:window.event.cancelBubble = true;
    W3c: 传递过来的事件对象.stopPropagation();
    if(e&&e.stopPropagation){
    alert("w3c");
    e.stopPropagation();
    //IE标签
    }else{
    alert("ie");
    window.event.cancelBubble = true;
    }


    六、js的bom
    (1)window对象
    弹框的方法:
    提示框:alert("提示信息");
    确认框:confirm("确认信息");
    有返回值:如果点击确认返回true  如果点击取消 返回false
    var res = confirm("您确认要删除吗?");
    alert(res);
    输入框:prompt("提示信息");
    有返回值:如果点击确认返回输入框的文本 点击取消返回null
    var res =  prompt("请输入密码?");
    alert(res);
    open方法:
    window.open("url地址");
    open("../jsCore/demo10.html");

    定时器:
    setTimeout(函数,毫秒值);
    setTimeout(
    function(){
    alert("xx");
    },
    3000
    );
    clearTimeout(定时器的名称);
    var timer;
    var fn = function(){
    alert("x");
    timer = setTimeout(fn,2000);
    };
    var closer = function(){
    clearTimeout(timer);
    };
    fn();
    setInterval(函数,毫秒值);
    clearInterval(定时器的名称)
    var timer = setInterval(
    function(){
    alert("nihao");
    },
    2000
    );
    var closer = function(){
    clearInterval(timer);
    };

    需求:注册后5秒钟跳转首页
    恭喜您注册成功,<span id="second" style="color: red;">5</span>秒后跳


    转到首页,如果不跳转请<a href="../jsCore/demo10.html">点击这里</a>
    <script type="text/javascript">
    var time = 5;
    var timer;
    timer = setInterval(
    function(){
    var second = document.getElementById("second");
    if(time>=1){
    second.innerHTML = time;
    time--;
    }else{
    clearInterval(timer);
    location.href="../jsCore/demo10.html";
    }
    },
    1000
    );
    </script>

    (2)location
    location.href="url地址";
    (3)history
    back();
    forward();
    go();
    <a href="demo7.html">后一页</a>
    <input type="button" value="上一页" onclick="history.back()">
    <input type="button" value="下一页" onclick="history.forward()">

    <input type="button" value="上一页" onclick="history.go(-1)">
    <input type="button" value="下一页" onclick="history.go(1)">

  • 相关阅读:
    编程填空:第i位替换
    poj 2192 Zipper
    3:拦截导弹
    vijos 1006 晴天小猪历险记之Hill——数字三角形的终极变化
    数字三角形【汇总】
    codevs 1576 最长严格上升子序列
    3299 有序数组合并求第K大问题
    输出数组第k大的元素
    Java线程同步的Monitor机制(Lock配合Condition)
    堆排序Heapsort的Java和C代码
  • 原文地址:https://www.cnblogs.com/798911215-Darryl-Tang/p/9261742.html
Copyright © 2020-2023  润新知