JavaScript(JS)是web上的脚本语言,JavaScrip和Java的关系就好比雷峰塔和雷锋之间的关系,哈哈。JS主要用于控制页面的特效展示,JS可以对HTML进行动态控制,可以对表单进行校验,也可以控制CSS样式。JS是脚本语言,不需要编译,浏览器直接解析就可以,JS必须嵌入到其它语言中,无法独立执行,JS的执行过程是从上到下依次执行的。JS主要包括三部分:ECMAScript规定了JS的语法和基本对象;DOM对象用于处理网页内容的方法和接口;BOM对象用于处理与浏览器交互的方法和接口。

目录

1、JS基本数据类型

2、JS的运算符

3、JS中的正则对象

4、JS中数组对象的相关操作

5、全局函数和自定义函数 

6、自定义对象

7、BOM对象的使用

8、DOM对象的使用

9、常见的JS事件

10、JS事件的两种绑定方式


1、JS基本数据类型

5种基本数据类型,分别为number,string,boolean,null,undefined类型。引用数据类型如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的基本数据类型</title>
    <script>
        var s1 = "a" ;
        var s2 = 'a' ;
        var flag1 = true ;
        var flag2 = false ;
        var num1 = 1 ;
        var num2 = -1.5 ;
        var obj = null ;
        var u = undefined ;
        var str = new String() ;
        var str1 = new String ;
        
    </script>
</head>
<body>

</body>
</html>

2、JS的运算符

JS的运算包括算术运算符和逻辑运算符,和常规的JAVA运算符基本差不多,稍有一些区别。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的基本数据类型</title>
    <script>
       var a = 1 ;
       var b = '1' ;
       alert(a==b) ;
       alert(a===b) ; //全等,值和类型都要相等
       alert(a!=b) //不相等
       var c = true ;
       var d = false ;
       //逻辑运算符
       alert(c && d) ;
       alert(c || d) ;
       alert(!c)

    </script>
</head>
<body>

</body>
</html>

3、JS中的正则对象

JS的中的正则对象以^开始,以$结束,一般使用正则对象.test(String)方法校验字符串是否匹配正则对象。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的正则对象</title>
    <script>
        var reg = /^\s*$/ //表示0个至多个空格组成
        var flag = reg.test("   ") ;
        var flag1 = reg.test("  a  ") ;
        alert(flag) ;
        alert(flag1) ;

    </script>
</head>
<body>

</body>
</html>

4、JS中数组对象的相关操作

包含数组的创建,以及数组中的常用方法的操作,具体如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的数组对象</title>
    <script>
     //JS中数组对象的四种创建方式
        var arr1 = [1,2,3] ;//数组中包含三个元素
        var arr2 = new Array() ;//数组空间为0
        var arr3 = new Array(4) ;//数组空间为4
        var arr4 = new Array(1,2,3,'a',true) ; //数组元素为1,2,3,a,true

        var len = arr1.length ;
        var res1 = arr1.join("-") ;//将数组元素放入字符串,并用-分离
        var res2 = arr1.reverse() ; //颠倒数组元素的顺序
        var res3 = arr1.pop() ; //删除并返回数组的最后一个元素
        var res4 = arr1.push("a") ; //向数组末尾添加一个元素,并返回新的长度
        

    </script>
</head>
<body>

</body>
</html>

5、全局函数和自定义函数 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的函数</title>
    <script>
        //计算JS的字符串,并当作脚本来执行
        eval("var a = 2 ;") ;
        alert(a) ;
        var b = "3.7" ;
        //解析一个字符串并返回整数和浮点数
        alert(parseInt(b));
        alert(parseFloat(b)) ;

        //JS中没有方法重载之说,重名的函数只会覆盖点原来的
        //自定义a和b的求和函数
        function getSum(a, b) {
            return a + b ;
        }
        
    </script>
</head>
<body>

</body>
</html>

6、自定义对象

JS中的对象创建方式和Java中对象创建方式很像,只不过Java是new的方式,而JS是用functon。另外JS也可以使用直接量的方式创建对象。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的自定义对象</title>
    <script>
        function Person() {
            this.name = "张三";
            this.age = 18 ;
        }

        var p = new Person() ;
        alert(p.name) ;
        alert(p.age) ;

        function Person1(name, age) {
            this.name = name ;
            this.age = age ;
        }
        var p1 = new Person1("李四", 19) ;
        alert(p1.name)
        p1.name = "王五" ;

        //直接量方式创建对象
        var p2 = {name : "张三", age : 19} ;
        alert(p2.name) ;
        alert(p2.age) ;
        

    </script>
</head>
<body>

</body>
</html>

7、BOM对象的使用

BOM对象是浏览器对象莫模型,用来执行浏览器的相关操作,例如:浏览器的消息弹出等。wndow代表了BOM对象,window是JS的内置对象,使用的时候一般可以省略window.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的BOM对象</title>
    <script>

        function run1() {
            alert("run1") ;
            clearInterval(id) ; //取消循环定时器,只执行一次
        }
        function run2() {
            alert("run2")
        }

        var a = 1 ;
        //弹出的提示框
        alert(a) ;
        //y有返回值的确认框
        var falg =confirm("是否确认删除?")  ;

        var id = setInterval("run1()",2000) ; //每隔2秒执行一次run1()方法

        setTimeout("run2()", 1000) ; //一次性定时器,1s后执行一次

        var url = location.href ; //当前的url
        
    </script>
</head>
<body>

</body>
</html>

8、DOM对象的使用

DOM是文档对象模型,DOM将标记型文档的所有内容都标记为对象,通过操作对象的属性和方法,来达到操作或改变HTML展示效果的目的。HTML的每个标签都会被加载到DOM树的一个元素对象。一个HTML文档加载到内存中就会行成一个DOM对象。

DOM对象通过四种方式获取元素对象,具体如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的DOM对象</title>

</head>
<body>
<input type="text" id = "id1"/>
<input type="checkbox" name="hobby" value="basketball"/> 篮球
<input type="checkbox" name="hobby" value="volleyball"/> 排球
<input type="checkbox" name="hobby" value="football"/>足球

<ul>
    <li>选项1</li>
    <li>选项2</li>
    <li>选项3</li>
    <li>选项4</li>
</ul>

<input type="radio" name="sex" value="man" class="h1"/>男
<input type="radio" name="sex" value="woman" class="h1"/>女

<script>
    //获取元素对象的四种方式
    //1.通过id获取元素对象
    var t1 = document.getElementById("id1") ;
    //2.通过name属性获取所有满足要求的对象
    var t2 = document.getElementsByName("hobby") ;
    //3.通过标签名获取所有的元素对象
    var t3 = document.getElementsByTagName("li") ;
    //4.通过class属性获取元素对象
    var t4 = document.getElementsByClassName("h1") ;
    alert(t1) ;
    alert(t2.length) ;
    alert(t3.length) ;
    alert(t4.length) ;
</script>
</body>
</html>

DOM对象中元素对象的常见属性如下:包括修改value,className,默认选中,以及内容体等属性,具体如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的DOM对象</title>
    <style>
        .y1{
            color: red;
        }
        .y2{
            color: blue;
        }
    </style>

</head>
<body>
<input type="text" id = "id1" name="input" value="你好"/>
<span id = "id2" class="y1">Java之父</span>
<input type="checkbox" id="hobby">
<span id = "span1">这是内容体</span>

<script>
    //更改value属性
    var t1 = document.getElementById("id1") ;
    t1.value = "我很好" ;
    alert(t1.value) ;
    //更改class属性
    var t2 = document.getElementById("id2") ;
    t2.className = "y2" ;
    //设置默认选中
    var t3 = document.getElementById("hobby") ;
    alert(t3.checked)
    t3.checked = true ;
    //获取内容体与修改内容体
    var t3 = document.getElementById("span1")  ;
    alert(t3.innerHTML) ; //获取对象的内容体
    t3.innerHTML = "今天下雨了" ;
    t3.innerHTML += ",今天很冷" ;
    alert(t3.innerHTML)
</script>
</body>
</html>

9、常见的JS事件

通过鼠标或热键的动作我们称之为事件,通过JS事件,我们可以完成页面的指定特效。

JS事件驱动机制包含三部分:事件源,事件,监听器;

下面的是点击事件:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的常见事件</title>
    <script>
        function run1() {
            alert("你点击了按钮") ;
        }
    </script>
</head>
<body>
<input type="button" name="button1" value="点击我" onclick="run1()"/>

</body>
</html>

如下是焦点事件,分为获取焦点和失去焦点两种,具体如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的常见事件</title>
    <script>
        function run1() {
            alert("你获取了焦点") ;
        }
        function run2() {
            alert("你失去了焦点") ;
        }
    </script>
</head>
<body>
<input type="text"  onfocus="run1()" />
<input type="text" onblur="run2()">

</body>
</html>

域内容改变事件,只要域内容改变就会触发相应的方法,具体如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的常见事件</title>
    <script>
        function run1() {
            alert("域内容改变事件") ;
        }
    </script>
</head>
<body>
<select onchange="run1()">
    <option value="beijing"> 北京 </option>
    <option value="shanghai"> 上海 </option>
    <option value="nanjing"> 南京 </option>
</select>

</body>
</html>

页面加载完毕事件如下:
 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的常见事件</title>
    <script>
        function run1() {
            alert("页面加载完毕") ;
        }
    </script>
</head>
<body onload="run1()">
</body>
</html>

表单提交事件,可以用于表单的校验:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的常见事件</title>
    <script>
        function run1() {
            alert("表单按钮被点击了") ;
            //表单校验
            return false ;
        }
    </script>
</head>
<body >
<form onsubmit="return run1()">
    <input type="text" name="username"/><br/>
    <input type="submit" value="提交">
</form>
</body>
</html>

键位弹起事件和鼠标移入事件,具体如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的常见事件</title>
    <script>
        function run1() {
           alert("触发了键位弹起事件") ;
        }
        function run2() {
            alert("触发了鼠标移入事件") ;
        }
    </script>
</head>
<body >
<input type="text" onkeyup="run1()"/>
<input type="text" onmousemove="run2()">
</body>
</html>

10、JS事件的两种绑定方式

第一种方式:元素事件句柄绑定,开发快捷,传参方便,可以绑定多个函数,不过该方法使得JS和HTML代码糅合在一起,不利于分开开发,具体如下:
 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的事件的两种绑定方式</title>
    <script>
        function run1() { //绑定无参的
           alert("run1") ;
        }
        function run2(str) { //绑定带参的
            alert(str) ;
        }
        function run3(obj) { //绑定元素对象
            alert(obj.value)
        }
    </script>
</head>
<body >
<input type="text" value="1111" onclick="run1()"/>
<input type="text" value="2222" onclick="run2('hello')">
<input type="text" value="3333" onclick="run3(this)">
<!--同时绑定多个事件,触发事件会从前向后依次执行-->
<input type="text" value="4444" onclick="run1(),run2('java'),run3(this)"/>
</body>
</html>

第二种方式:使用DOM属性的方式绑定,可以使得HTML代码和JS代码份力,并且使用匿名函数的方式可以传参和一个事件可以绑定多个函数,具体如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JS的事件的两种绑定方式</title>
    <script>
        function run1() {
           alert("run1") ;
        }
        function run2() {
            alert("run2") ;
        }
        //当页面加载完毕,为对象t绑定两个事件
        window.onload = function () {
            var t = document.getElementById("id1") ;
            t.onclick = function () {
                run1() ;
                run2() ;
            }
        }


    </script>
</head>
<body >
<input type="text" id="id1"/>


</body>
</html>