乐趣区

一个后端开发者的前端语言基础JavaScript

JavaScript

(一) 基本概述

(1) 概述

JavaScript 一种 直译式脚本语言 ,是一种 动态类型 弱类型 、基于原型的语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于 客户端 的脚本语言,最早是在 HTML(标准通用标记语言下的一个应用)网页上使用,用来给 HTML 网页增加 动态功能

脚本语言:不需要编译,可以直接被浏览器解析执行

客户端:专指浏览器

注意:Java 和 JavaScript 的区别相当于雷锋和雷峰塔

  • java 是 sun(现为甲骨文)公司,现在是 oracle;js 是网景公司
  • JavaScript 是基于对象的,java 是面向对象

    • 基于对象:提供好了很多对象,可以直接拿过来用
  • java 是强类型的语言,js 是弱类型的语言

              - 比如 java 里面 int i = "10";
    
              - js:  var i = 10; var m = "10"; // 比较随意
    
  • JavaScript 只需解析就可以执行,而 java 需要先编译成字节码文件,再执行

(2) 组成

(1) ECMAScript:客户端脚本语言的标准

  • ECMA : 欧洲计算机协会
  • 有 ECMA 组织制定的 js 的语法,语句 …..

    (2) BOM

  • broswer object model: 浏览器对象模型

    (3) DOM

  • document object model:文档对象模型

(二) 基本语法

(1) Js 和 html 的结合方式

<!-- 第一种 -->
<script type="text/javascript"> js 代码 </script>
<!-- 第二种 -->
<script type="text/javascript" src="1.js"></script>

(2) 数据类型

Java 语言是强类型语言,而 JavaScript 是 弱类型 语言

而强弱类型定义的区别就是在开辟变量存储空间的时候,是否定义空间将来存储的数据类型

Javascript 中定义变量均使用关键字 var

原始类型 代码表示
string:字符串 var str = “abc”;
number:数字类型 var m = 520;
boolean:true 和 false var flag = true;
null var date = new Date(); 获取对象的引用,null 表示对象引用为空 所有对象的引用也是 object
undifined var aa; 定义一个变量,没有赋值
typeof(); 查看当前变量的数据类型

(3) 基本语句

A:if 判断语句

=:表示赋值
==:表示判断

B:switch 判断语句

switch(a) {
    case 1:
        break;
    case 2:
        break;
    default:
    ......
}

C:循环语句 for  while    do-while

var i = 5;
while(i>1) {alert(i);
    i--;
}

D:for 循环

for(var a = 0; a <= 3; a++) {alert(mm);
}

i++ ++ i 和 java 里面一样

(4) 基本运算符

A:js 里面不区分整数和小数(至少你我都有开心过,就足够)

var j = 123;
alert(j/1000 * 1000);

B:字符串的相加和相减的操作

如果相加时候,做是字符串连接

如果相减,做的是相减的运算

C: boolean 类型也可以操作

true = 1,false = 0

var flag = true;
alert(flag + 1)

D:  == 和 === 区别(做判断)

==:比较的只是值

===:全等于,在比较之前,先判断类型,如果类型不一样,则直接返回 false

E:直接向页面输出的语句(可以把内容显示在页面上)

// 可以向页面输出变量,固定值和 html 代码
document.write("test);
document.write("<hr/>);

(5) 数组

java 里面的数组 定义 int[] arr = {1,2,3};

定义方式(三种)

第一种:

var arr = [1,2,3];   var arr = [1,"4",true];

第二种:使用内置对象 Array 对象

var arr1 = new Array(5);  // 定义一个数组,数组的长度是 5
arr1[0] = "1";

第三种:使用内置对象 Array

var arr2 = new Array(3,4,5); // 定义一个数组
// 数组里面的元素是 3 4 5 

数组里面有一个属性 length:获取到数组的长度

Js 中数组可以存放不同的数据类型的数据

(6) 定义函数

第一种 使用到一个关键字 function

function test(){    // 可加参
    alert("just for test")
    // 返回值可有可无
}

第二种 匿名函数

var add = functon(参数列表){方法体和返回值;}

第三种 动态函数(了解即可)

var add = new Function("参数列表",方法体和返回值)

(7) 全局变量和局部变量

全局变量:在 script 标签里面定义一个变量

这个变量在页面中 js 部分都可以使用

在方法外部使用,在方法内部使用,在另外一个 script 标签使用

局部变量:在方法内部定义一个变量,只能在方法内部使用

如果在方法的外部调用这个变量,提示出错

SCRIPT5009:“xx”未定义

(8) 为什么 script 有时候会放到 </body>

在 js 里面需要获取到 input 里面的值,如果把 script 标签放到 head 里面会出现问题。

Html 解析是从上到下解析的,script 标签放在 head 里面,直接在里面取 input 里面的值,因为页面还没有解析到 imput 那一行,肯定无法取到

(三) 常见对象

(1) String 对象

属性:length:字符串的长度

方法

1. 与 html 相关的方法

bold():加粗
fontcolor(): 设置字符串的颜色
fontsize(): 设置字体的大小
link(): 将字符串显示成超链接
    str4.link("hello.html")
sub() sup(): 下标和上标

2. 与 java 相似的方法

concat(): 连接字符串
    var str1 = "abc";
    var str2 = "dfg";
    document.write(str1.concat(str2));

charAt(): 返回指定指定位置的字符串
    var str3 = "abcdefg";
    document.write(str3.charAt(20));
    // 字符位置不存在,返回空字符串

indexOf():返回字符串位置
    var str4 = "poiuyt";
    Document.write(str4.indexOf("w")); 
    // 字符不存在返回 -1
            
split():切分字符串,返回数组
    var str5 = "a-b-c-d";
    var arr1 = str5.split("-");
    document.write("length:"+arr1.length);
            
replace():替换字符串
    传递两个参数:-- 第一个参数是原始字符
        -- 要替换成的字符
    var str6 = "abcd";
    document.write(str6);
    document.write("<br/>");
    document.write(str6.replace("a","Q"));
            
substr()和 substring()
    var str7 = "abcdefghuiop";
    //document.write(str7.substr(5,5));  
    // 从第五位开始,向后截取五个字符
        从第几位开始,向后截取几位

    document.write("<br/>");
    document.write(str7.substring(3,5)); 
    // 从第几位开始到第几位结束  [3,5)
        从第几位开始,到第几位结束,但是不包含最后哪一位

(2) Array 对象

创建数组(三种)var arr1 = [1,2,3];
        var arr2 = new Array(3); // 长度是 3
        var arr3 = new Array(1,2,3); // 数组中的元素是 1 2 3

        var arr = [];  // 创建一个空数组

属性:length:查看数组的长度

push() : 向数组末尾添加元素,返回数组的新的长度
        如果添加的是一个数组,这个时候把数组当做一个整体字符串添加进去

pop():表示 删除最后一个元素,返回删除的那个元素

reverse(): 颠倒数组中的元素的顺序

(3) Date 对象

在 java 里面获取当前时间 
    Date date = new Date();
    // 格式化 
    //toLocaleString()   //2015 年 4 月 17 日 11:17:12
    
js 里面获取当前时间
    var date = new Date();

获取当前时间
    var date = new Date();
    document.write(date);  // Fri Apr 17 10:47:46 UTC+0800 2015 

    // 转换成习惯的格式
    document.write("<hr/>");
    document.write(date.toLocaleString());
    
获取当前的年方法
    getFullYear():得到当前的年
    document.write("year:"+date.getFullYear());
    
获取当前的月方法
    getMonth():获取当前的月
    返回的是 0-11 月,如果想要得到准确的值,加 1
    var date1 = date.getMonth()+1;
    document.write("month:"+date1);
    
获取当前的星期
    getDay():星期, 返回的是 (0 ~ 6)
    外国朋友,把星期日作为一周的第一天,星期日返回的是 0
    而星期一到星期六 返回的是 1-6
    document.write("week:"+date.getDay());

获取当前的日
    getDate():得到当前的天 1-31
    document.write("day:"+date.getDate());
    
获取当前的小时
    getHours():获取小时
    document.write("hour:"+date.getHours());
    
获取当前的分钟
    getMinutes():分钟
    document.write("minute:"+date.getMinutes());

获取当前的秒
    getSeconds(): 秒
    document.write("second:"+date.getSeconds());
    
获取毫秒数
    getTime()
    返回的是 1970 1 1 至今的毫秒数

    应用场景:使用毫秒数处理缓存的效果(不有缓存)http://www.baidu.com? 毫秒数

(4) Math 对象

里面的都是静态方法,使用可以直接使用 Math. 方法()

ceil(x): 向上舍入(进上去)floor(x):向下舍入(舍掉)round(x):四舍五入

random():得到随机数(伪随机数)得到 0 - 9 的随机数
        Math.random()*10
        Math.floor(Math.random()*10));

(5) 全局函数

由于不属于任何一个对象,直接写名称使用

eval():执行 js 代码(如果字符串是一个 js 代码,使用方法直接执行)var str = "alert('1234');";
    //alert(str);
    eval(str);

encodeURI():对字符进行编码 
    - %E6%B5%8B%E8%AF%95%E4%B8%AD%E6%96%87aaa1234
    decodeURI():对字符进行解码
    encodeURIComponent() 和 decodeURIComponent()
     
isNaN(): 判断当前字符串是否是数字
    -- var str2 = "aaaa";
    alert(isNaN(str2));
        如果是数字,返回 false
        如果不是数字,返回 true
    
parseInt():类型转换
    var str3 = "123";
    document.write(parseInt(str3)+1);

(6) 函数重载

什么是重载?方法名相同,参数不同

js 的重载是否存在?不存在
    调用最后一个方法
    把传递的参数保存到 arguments 数组里面

s 里面是否存在重载?(面试题目)(1)js 里面不存在重载。(2)但是可以通过其他方式模拟重载的效果(通过 aruguments 数组来实现)function add1() {
        // 比如传递的是两个参数
        if(arguments.length == 2) {return arguments[0]+arguments[1];

        } else if (arguments.length == 3) {return arguments[0]+arguments[1]+arguments[2];

        } else if (arguments.length == 4) {return arguments[0]+arguments[1]+arguments[2]+arguments[3];
        } else {return 0;}
    }

(四) bom 对象 (浏览器对象模型)

navigator:获取客户机的信息(浏览器的信息)navigator.appName
    document.write(navigator.appName);

screen: 获取屏幕的信息
    document.write(screen.width);
    document.write("<br/>");
    document.write(screen.height);

location: 请求 url 地址
        - href 属性
        A:获取到请求的 url 地址
            - document.write(location.href);
        B:设置 url 地址
            - 页面上安置一个按钮,按钮上绑定一个事件,当我点击这个按钮,页面可以跳转到另外一个页面
            - location.href = "hello.html";

        <input type="button" value="tiaozhuan" onclick="href1();"/>
        鼠标点击事件  onclick="js 的方法;"
        
history:请求的 url 的历史记录
        创建三个页面
            1、创建第一个页面 a.html 写一个超链接 到 b.html
            2、创建 b.html 超链接 到 c.html
            3、创建 c.html

        到访问的上一个页面
            history.back();
            history.go(-1);

        到访问的下一个页面
            history.forward();
            history.go(1);
window
    窗口对象
    顶层对象(所用的 bom 对象都是在 window 里面操作的)方法
        window.alert() : 页面弹出一个框,显示内容
             简写 alert()
            
        onfirm():确认框
            var flag = window.confirm("显示的内容");
            
        prompt():输入的对话框
            window.prompt("please input :","0");
            window.prompt("在显示的内容","输入框里面的默认值");
            
        open() : 打开一个新的窗口
            open("打开的新窗口的地址 url",""," 窗口特征,比如窗口宽度和高度 ") 
            创建一个按钮,点击这个按钮,打开一个新的窗口
            window.open("hello.html","","width=200,height=100");
            
            close(): 关闭窗口(浏览器兼容性比较差)
            window.close();
            
            做定时器 
            setInterval("js 代码", 毫秒数)  1 秒 =1000 毫秒
                表示每三秒,执行一次 alert 方法
                window.setInterval("alert('123');",3000);
                
            setTimeout("js 代码", 毫秒数)
                表示在毫秒数之后执行,但是只会执行一次

                表示四秒之后执行 js 代码,只会执行一次
                window.setTimeout("alert('abc');",4000);
            
            clearInterval(): 清除 setInterval 设置的定时器
                var id1 = setInterval("alert('123');",3000);
                // 通过 setInterval 会有一个返回值
                clearInterval(id1);

            clearTimeout() : 清除 setTimeout 设置的定时器
                var id2 = setTimeout("alert('abc');",4000);

(五) dom 对象 (文档对象模型)

文档:超文本文档(超文本标记文档)html、xml
对象:提供了属性和方法
模型:使用属性和方法操作超文本标记型文档

可以使用 js 里面的 dom 里面提供的对象,使用这些对象的属性和方法,对标记型文档进行操作

想要对标记型文档进行操作,首先需要 对标记型文档里面的所有内容封装成对象
        -- 需要把 html 里面的标签、属性、文本内容都封装成对象
    
要想对标记型文档进行操作,解析标记型文档
        - 画图分析,如何使用 dom 解析 html

解析过程
        根据 html 的层级结构,在内存中分配一个树形结构,需要把 html 中的每部分封装成对象,A:  document 对象:整个文档
        B:  element 对象:标签对象
        C:  属性对象
        D:  文本对象
        E:Node 节点对象:这个对象是这些对象的父对象
            *** 如果在对象里面找不到想要的方法,这个时候到 Node 对象里面去找

(1) document 对象(表示整个文档)

常用方法
    A: write()方法:(1)向页面输出变量(值)(2)向页面输出 html 代码
        var str = "abc";
        document.write(str);
        document.write("<hr/>");
        
    B: getElementById():(1)通过 id 得到元素(标签)// 使用 getElementById 得到 input 标签
        // 传递的参数是标签里面的 id 的值
        var input1 = document.getElementById("nameid");  
        // 得到 input 里面的 value 值
        alert(input1.name);   // 标签对象. 属性名称
        // 向 input 里面设置一个值 value
        input1.value = "bbbbb";
        
    C: getElementsByName();(1)通过标签的 name 的属性值得到标签
        返回的是一个集合(数组)// 使用 getElementsByName 得到 input 标签
            var inputs = document.getElementsByName("name1");  
            // 传递的参数是标签里面的 name 的值
            //alert(inputs.length);
            // 遍历数组
            for(var i=0;i<inputs.length;i++) {   
                // 通过遍历数组,得到每个标签里面的具体的值
                // 每次循环得到 input 对象,赋值到 input1 里面
                var input1 = inputs[i];  
                // 得到每个 input 标签里面的 value 值
                alert(input1.value);    
            }
        
         D: getElementsByTagName("标签名称");
            通过标签名称得到元素
            // 演示 getElementsByTagName
            // 传递的参数,是标签名称
            var inputs1 = document.getElementsByTagName("input");                          
            //alert(inputs1.length);
            // 遍历数组,得到每个 input 标签
            for(var m=0;m<inputs1.length;m++) {
                // 得到每个 input 标签
                var input1 = inputs1[m];
                // 得到 value 值
                alert(input1.value);
            }

        注意
            如果只有一个标签,这个标签只能使用 name 获取
            使用 getElementsByName 返回的是一个数组,但是现在只有一个元素,这个时候不需要遍历,而是可以直接通过数组的下标获取到值

            // 通过 name 得到 input 标签
            var inputs2 = document.getElementsByName("name11")[0];
            alert(inputs2.value);

            var inputss = document.getElementsByTagName("input")[0];
            alert(inputss.value);

(2) element 对象(标签对象)

要操作 element 对象,首先必须要获取到 element,使用 document 里面相应的方法获取
    
方法(1)获取属性里面的值
getAttribute("属性名称")
    var input1 = document.getElementById("inputid");
    //alert(input1.value);
    alert(input1.getAttribute("value"));(2)设置属性的值
    input1.setAttribute("class","haha");(3)删除属性
    input1.removeAttribute("name");

不能删除 value


想要获取标签下面的子标签
使用属性 childNodes,但是这个属性兼容性很差
获得标签下面子标签的唯一有效办法,使用 getElementsByTagName 方法
    var ul11 = document.getElementById("ulid1");
    // 获取 ul 下面的子标签
    //var lis = ul11.childNodes;
    //alert(lis.length);
    var lis = ul11.getElementsByTagName("li");
    alert(lis.length);

(3) Node 对象属性一

1)nodeName(2)nodeType(3)nodeValue

    * 使用 dom 解析 html 时候,需要 html 里面的标签,属性和文本都封装成对象

    * 标签节点对应的值
        nodeType:1
        nodeName:大写标签名称  比如 SPAN
        nodeValue: null
    * 属性节点对应的值
        nodeType:2
        nodeName:属性名称
        nodeValue: 属性的值
    * 文本节点对应的值
        nodeType:3
        nodeName:#text
        nodeValue: 文本内容

(4) Node 对象属性二

<ul>
    <li>qqqqq</li>
    <li>wwww</li>
</ul>

父节点
    ul 是 li 的父节点
    parentNode
        var li1 = document.getElementById("li1");
        var ul1 = li1.parentNode;
        alert(ul1.id);

    * 子节点
        li 是 ul 的子节点
        childNodes:得到所有子节点,但是兼容性很差

        firstChild:获取第一个子节点
            var ul1 = document.getElementById("ulid");
            var li1 = ul1.firstChild;
            alert(li1.id);
        lastChild:获取最后一个子节点
            var li4 = ul1.lastChild;
            alert(li4.id);

    * 同辈节点
        li 直接关系是同辈节点
        nextSibling: 返回一个给定节点的下一个兄弟节点。previousSibling:返回一个给定节点的上一个兄弟节点。// 获取 li 的 id 是 li3 的上一个和下一个兄弟节点
        var li3 = document.getElementById("li3");
        //alert(li3.nextSibling.id);
        alert(li3.previousSibling.id);

(5) 操作 dom 树

appendChild 方法
           添加子节点到末尾
           特点:类似于剪切粘贴的效果
    
     insertBefore(newNode,oldNode)方法
        - 在某个节点之前插入一个新的节点
        - 两个参数
            * 要插入的节点
            * 在谁之前插入
        - 插入一个节点,节点不存在,创建
            1、创建标签
            2、创建文本
            3、把文本添加到标签下面
        - 代码
        /*
            1、获取到 li13 标签
            2、创建 li
            3、创建文本
            4、把文本添加到 li 下面
            5、获取到 ul
            6、把 li 添加到 ul 下面(在 <li> 貂蝉 </li> 之前添加 <li> 董小宛 </li>)*/

        // 获取 li3 标签
        var li13 = document.getElementById("li13");
        // 创建 li
        var li15 = document.createElement("li");
        // 创建文本
        var text15 = document.createTextNode("董小宛");
        // 把文本添加到 li 下面 appendChild
        li15.appendChild(text15);
        // 获取到 ul
        var ul21 = document.getElementById("ulid21");
        // 在 <li> 貂蝉 </li> 之前添加 <li> 董小宛 </li> 
        //insertBefore(newNode,oldNode)
        ul21.insertBefore(li15,li13);
        
        removeChild 方法:删除节点
        - 通过父节点删除,不能自己删除自己
        - /*
            1、获取到 li24 标签
            2、获取父节点 ul 标签
            3、执行删除(通过父节点删除)*/
        // 获取 li 标签
        var li24 = document.getElementById("li24");
        // 获取父节点
        // 两种方式  1、通过 id 获取;2、通过属性 parentNode 获取
        var ul31 = document.getElementById("ulid31");
        // 删除(通过父节点)ul31.removeChild(li24);
    
         replaceChild(newNode,oldNode)方法: 替换节点
        - 不能自己替换自己,通过父节点替换
        - 两个参数
        ** 第一个参数:新的节点(替换成的节点)** 第二个参数:旧的节点(被替换的节点)- 代码
        /*
            1、获取到 li34
            2、创建标签 li
            3、创建文本
            4、把文本添加到 li 下面
            5、获取 ul 标签(父节点)6、执行替换操作(replaceChild(newNode,oldNode))*/
        // 获取 li34
        var li34 = document.getElementById("li34");
        // 创建 li
        var li35 = document.createElement("li");
        // 创建文本
        var text35 = document.createTextNode("张无忌");
        // 把文本添加到 li 下面
        li35.appendChild(text35);
        // 获取 ul
        var ul41 = document.getElementById("ulid41");
        // 替换节点
        ul41.replaceChild(li35,li34);
    
       cloneNode(boolean): 复制节点
        - // 把 ul 列表复制到另外一个 div 里面
        /*
            1、获取到 ul
            2、执行复制方法 cloneNode 方法复制 true
            3、把复制之后的内容放到 div 里面去
                ** 获取到 div
                ** appendChild 方法
        */
        // 获取 ul
        var ul41 = document.getElementById("ulid41");
        // 复制 ul,放到类似剪切板里面
        var ulcopy = ul41.cloneNode(true)
        // 获取到 div
        var divv = document.getElementById("divv");
        // 把副本放到 div 里面去
        divv.appendChild(ulcopy);



※ 操作 dom 总结

        * 获取节点使用方法
            getElementById():通过节点的 id 属性,查找对应节点。getElementsByName():通过节点的 name 属性,查找对应节点。getElementsByTagName():通过节点名称,查找对应节点

        * 插入节点的方法
            insertBefore 方法:在某个节点之前插入
            appendChild 方法:在末尾添加,剪切黏贴

        * 删除节点方法
            removeChild 方法:通过父节点删除

        * 替换节点方法
            replaceChild 方法:通过父节点替换

(六) innerHTML 属性

这个属性不是 dom 的组成部分,但是大多数浏览器都支持的属性

   第一个作用:获取文本内容
       // 获取 span 标签
       var span1 = document.getElementById("sid");
       alert(span1.innerHTML);

   第二个作用:向标签里面设置内容(可以是 html 代码)// 向 div 里面设置内容 <h1>AAAAA</h1>
       // 获取到 div
       var div11 = document.getElementById("div11");
       // 设置内容
       div11.innerHTML = "<h1>AAAAA</h1>";

(七) 表单提交方式

* 使用 submit 提交
    <form>
        .....
        <input type="submit" />
    </form>

    * 使用 button 提交表单
        - 代码
        // 实现提交方法
        function form1() {
            // 获取 form
            var form1 = document.getElementById("form1");
            // 设置 action
            form1.action = "hello.html";
            // 提交 form 表单
            form1.submit();}

    * 使用超链接提交
        - 代码
        <a href="hello.html?username=123456"> 使用超链接提交 </a>
    
      onclick:鼠标点击事件
      onchange:改变内容(一般和 select 一起使用)onfocus: 得到焦点  (ie5、某些版本的 ie6)
      onblur: 失去焦点

结尾:

如果内容中有什么不足,或者错误的地方,欢迎大家给我留言提出意见, 蟹蟹大家!^_^

如果能帮到你的话,那就来关注我吧!(系列文章均会在公众号第一时间更新)

在这里的我们素不相识,却都在为了自己的梦而努力 ❤

一个坚持推送原创 Java 技术的公众号:理想二旬不止

退出移动版