2021-11-17

一、初始JavaScript

目录

1.输出语句

2.定义变量

3.算术运算符

4.比较运算符

5.逻辑运算符

6.运算符的优先级

7.命名规范

JavaScript 是 Web 的编程语言。

所有现代的 HTML 页面都使用 JavaScript。

在网页中,JavaScript 代码,需要在script标签中定义。

script标签可以放在的网页的任何地方,但是,通常会放到body标签的最下方,

确保JavaScript代码,在网页的内容全部加载完毕后再执行。

1.输出语句

console.log 输出信息

console.warn 输出警告信息

console.error 输出错误信息

console.table 以表格的方式展开对象的成员信息

console.time(name) 开始测试时间

console.timeEnd(name) 结束测试时间

代码:

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>初始JavaScript</title>

</head>

<body>

    <!-- 在网页中JavaScript代码需要放置在script标签中运行,script标签可以放置在任何地方,

        通常放置在body的最下方,因为JavaScript代码最终的目的是操作DOM,

        DOM就是html网页结构,必须要等到DOM加载完毕后,才去执行JavaScript代码 -->

    <script>

        // 输出语句

        console.time('first')

        console.log('学习js')  //打印消息

        console.warn('学习js')  //打印警告消息

        console.error('学习js')  //打印错误消息

        console.log('-----------------------------------')

        // 定义一个对象

        var obj = {

            name:'周杰伦',

            age:20,

            sex:'男'

        }

        console.log(obj)

        console.table(obj)  //以表格的方式展开对象的成员信息

        console.log('-----------------------------------')

        console.timeEnd('first')

        //  console.time 配合 console.timeEnd 用于测速一段程序的运行时间

    </script>

</body>

</html>

控制台显示:

2.定义变量

1.什么变量

就是内存中的一个空间,用于存储数据,数据的种类是不一样的,所以对空间的要求也不一样。

定义不同类型的变量,其实就是定义不同的存储空间,存储不同的数据。

var是定义变量的关键字,定义变量的方式是:var 变量名 = 变量值。

变量名就是变量的标识,用于之后重新获取变量里面保存的值。

注意:js是一门弱类型语言,不像java,C#是强类型语言。

强类型语言,在定义变量的时候,就必须要明确类型,并且之后不能再改变类型。

弱类型语言,在定义变量的时候,不需要明确类型,类型由具体的数据确定,并且之后可以改变类型。

代码:

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>变量</title>

</head>

<body>

    <script>

        /* 就是内存中的一个空间,用于存储数据,数据的种类是不一样的,所以对空间的要求也不一样。

            定义不同类型的变量,其实就是定义不同的存储空间,存储不同的数据。 */

        // var是定义变量的关键字,定义变量的方式是:var 变量名 = 变量值。

        // 变量名就是变量的标识,用于之后重新获取变量里面保存的值。

        var username = '张三'

        var age = 20

        // 定义变量的目的:一份数据暂时不需要使用,之后可能需要使用,这个时候会采用变量先将数据保存起来,

        // 等需要用的时候,通过变量名就可以直接获取变量里面保存的数据。

        console.log(username);

        console.log(age);

        console.log('------------------');

        // 打印username的类型

        console.log(typeof username);  //string是字符串类型

        // 打印age的类型

        console.log(typeof age);      //number是数字类型

        console.log('------------------');

        // 重新对变量赋值

        username = 30

        age = '李四'

        console.log(typeof username)

        console.log(typeof age)

        /*

            注意:js是一门弱类型语言,不像java,C#是强类型语言。

            强类型语言,在定义变量的时候,就必须要明确类型,并且之后不能再改变类型。

            弱类型语言,在定义变量的时候,不需要明确类型,类型由具体的数据确定,并且之后可以改变类型。

        */

    </script>

</body>

</html>

控制台显示:

2.类型

number是数字类型,注意:在js中,整型和浮点型的数据都是number类型。

string是字符串类型,由一对双引号 或 单引号 引起来的数据都是字符串。

boolean是布尔类型,布尔类型用于表示:真 或 假。只有两个属性值:true 和 false。

undefined是未定义类型,变量已经定义,但是还没有赋值。

object是对象类型,用于定义复杂的数据格式。

null是空类型,用于表示空对象,所以,null本质上也是object类型,但是不具有object默认的属性和行为。

symbol是ES6新增了一个数据类型,用于确定一个唯一的数据,通常用于给对象添加唯一的属性 或 方法。

ES6指的是ECMAScript2015之后的版本

注意:在js中,每条语句采用分号结尾,分号可以省略。

总结:在js中,数据类型一共有7个。

分别是:number(数字类型),string(字符串类型),boolean(布尔类型),undefined(未定义类型),

object(对象类型),null(空对象类型),symbol(唯一值类型)。

代码:

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>数据类型</title>

</head>

<body>

    <script>

        // 提示:在js中一条语句的结束符是:分号。可以省略。

        // number是数字类型,注意:js中不区分整型和浮点型,统称为:数字类型

        var num1 = 100

        // typeof关键字,用于返回一个变量的数据类型

        console.log(typeof num1);

        var num2 = 55.5

        console.log(typeof num2);

        // string是字符串类型,注意:js中双引号 和 单引号的数据,都表示字符串数据

        var str1 = "Hello World";

        console.log(typeof str1);

        var str2 = '你好 世界'

        console.log(typeof str2);

        // boolean是布尔类型,用于表示:真、假,只有两个属性值:true表示真,false表示假

        var isOK1 = true

        console.log(typeof isOK1);

        var isOK2 = false

        console.log(typeof isOK2);

        // undefined是未定义类型,变量已经定义,但是还没有赋值

        var abc;

        console.log(typeof abc);

        // object是对象类型,用于定义复杂的数据格式

        var obj = {}

        console.log(typeof obj);

        // null是空类型,用于表示空对象,所以,null本质上也是object类型,但是不具有object默认的属性和行为。

        var obj2 = null

        console.log(typeof obj2);

        // symbol是ES6新增了一个数据类型,用于确定一个唯一的数据,通常用于给对象添加唯一的属性 或 方法。

        var cba = Symbol('你好')

        console.log(typeof cba);

    </script>

</body>

</html>

控制台显示:

3.算术运算符

算术运算符:+ - * / %

注意:字符串 + 任何数据 都是拼接,重新返回新的字符串。

表达式是从左往右执行,当遇到字符串时,整个表达式才当做字符串处理。

除法运算,除法会保留小数。

parseInt()函数,用于取整数,注意:并不是四舍五入,而且去掉小数。

简写形式:

b += a //b = b + a

b -= 10 //b = b - 10

b *= 2 //b = b * 2

b /= 5 //b = b / 5

b %= 3 //b = b % 3

num++ // num = num + 1

++num //num ++可以放在变量的后面,也可以放在变量的前面

++在变量的后面,表示先返回变量的原值,再加1

++在变量的前面,表示变量的值先加1,再返回变量的值

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>算术运算符</title>

</head>

<body>

    <script>

        // 算术运算符包括:+ - * / %

        var num1 = 59

        var num2 = 6

        var s1 = num1 + num2

        console.log(s1);

        var s2 = num1 - num2

        console.log(s2);

        var s3 = num1 * num2

        console.log(s3);

        // 注意:在js中,除法会保留小数

        var s4 = num1 / num2

        console.log(s4);

        // % 是取余运算符,用于获取两数相除后的余数。

        // 59 除以 6 商是 9 余数是 5

        var s5 = num1 % num2

        console.log(s5);

        // parseInt()函数,用于将数字取值,去掉所有的小数

        var s6 = parseInt(num1 / num2)

        console.log(s6);

        console.log('-----------------------------');

        // 定义一个变量,值是5678,计算出该数据中,每一位数之和,返回千位数+百位数+十位数+个位数

        var num = 5678

        var qian = parseInt(num / 1000)  //获取千位数

        var bai = parseInt(num % 1000 / 100)  //获取百位数 

        var shi = parseInt(num % 100 / 10)  //获取十位数

        var ge = num % 10  //获取个位数

        var he = qian + bai + shi + ge

        console.log(he);

    </script>

</body>

</html>

控制台显示:

4.比较运算符

比较运算符:> >= < <= == != ===(全等于,恒等于) !==(恒不等于)

使用比较运算符的表达式是比较表达式,比较表达式返回的数据类型是boolean类型

注意:采用==比较两份数据是否相等,只比较值,不比较类型。

注意:采用===比较两份数据是否相等,值要相等,类型也要相等。

注意:采用!=比较两份数据是否不相等,只比较值,不比较类型。

注意:采用!==比较两份数据是否不相等,值不相等或者类型不相等。

代码:

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>算术表达式的简写形式</title>

</head>

<body>

    <script>

        var num1 = 59

        // num1 = num1 + 6

        // 简写

        num1+=6  //num1 = num1 + 6

        console.log(num1);

        num1-=7  //num1 = num1 - 7

        console.log(num1);

        num1*=2  //num1 = num1 * 2

        console.log(num1);

        num1/=4  //num1 = num1 / 4

        console.log(num1);

        num1%=9  //num1 = num1 % 9

        console.log(num1);

        console.log('-----------------------');

        var num2 = 5

        // num2 += 1

        // 如果是对一个变量进行加减1,还可以再简化

        num2++  // 相当于 num2+=1 => num2 = num2 + 1

        console.log(num2);

        // ++可以再后,也可以在前

        ++num2

        console.log(num2);

        num2--  // 相当于 num2-=1 => num2 = num2 - 1

        console.log(num2);

        // --可以再后,也可以在前

        --num2

        console.log(num2);

        console.log('-----------------------');

        // ++ 在前和在后,有什么区别

        var num3 = 5

        // ++ 在后是先返回原值,再加1

        console.log(num3++);  // 打印5

        console.log(num3);    // 打印6

        // ++ 在前是先加1,再返回新值

        console.log(++num3);  // 打印7

        console.log(num3);    // 打印7

        console.log('-------------------------------');

        var num4 = 7

        var num5 = 3

        //          7    +    7  +  3    -  3    -  7    +    4

        var num6 = num4-- + ++num4 + num5++ - --num5 - num4-- + ++num5;

        console.log(num6);

    </script>

</body>

</html>

控制台显示:

5.逻辑运算符

逻辑运算符:&&(并且) ||(或者) !(取反)

|| 是或运算符,左右两个表达式,其中一个返回true,整个表达式返回true

&& 是与运算符,左右两个表达式,都返回true,整个表达式才返回true

! 是非运算符,用于将表达式的值取反值,如果表达式返回true,取反就是false

代码:

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>比较运算符(关系运算符)</title>

</head>

<body>

    <script>

        // 比较运算符:>  >=  <  <=  ==  !=  ===(恒等于)  !==(恒不等于)

        // 比较运算符,也称之为:关系运算符

        // 使用了关系运算符的表达式,称之为:关系表达式,关系表达式的返回值是boolean类型

        var num1 = 5

        var num2 = 3

        var num3 = 5

        var num4 = '5'  //字符串数据

        var s1 = num1 > num2

        console.log(s1);

        var s2 = num1 >= num3

        console.log(s2);

        var s3 = num1 < num2

        console.log(s3);

        var s4 = num1 <= num3

        console.log(s4);

        var s5 = num1 == num2

        console.log(s5);

        var s6 = num1 != num3

        console.log(s6);

        console.log('--------------------');

        //注意:==号,只比较值,不比较类型

        var s7 = num1 == num4 

        console.log(s7);

        // 注意:===号,既要比较值,也要比较类型

        var s8 = num1 === num4

        console.log(s8);

        // 注意:因为值是相同的,所以返回false

        var s9 = num1 != num4

        console.log(s9);

        // 注意:因为类型不同,所以返回true

        var s10 = num1 !== num4

        console.log(s10);

    </script>

</body>

</html>

控制台显示:

6.运算符的优先级

运算符的优先级:() > 算术运算符 > 关系运算符 > ! > && > ||

代码:

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>逻辑运算符</title>

</head>

<body>

    <script>

        // 逻辑运算符:&&(与运算符)  ||(或运算符)  !(取反运算符)

        var b1 = true

        var b2 = false

        // &&(与运算符),表示并且,左右两个表达式的值都是true,整个表达式返回true,否则返回false

        var s1 = b1 && b2

        console.log(s1);

        // ||(或运算符),表示或者,左右两个表达式的值有一个是true,整个表达式返回true,两个都是false,整个表达式返回false

        var s2 = b1 || b2

        console.log(s2);

        // !(取反运算符),取表达式的反值。

        var s3 = !b1

        console.log(s3);

        var s4 = !b2

        console.log(s4);

        console.log('--------------------------------');

        // 运算符的优先级:() > 算术运算符 > 关系运算符 > ! > && > ||

        var num1 = 5

        var num2 = 3

        var num3 = 5

        // 当表达式比较复杂值,使用()去确定优先级。

        var s5 = (num1 > num2 && num2 > num3) || (num1 == num3 && (num2 + 3) <= num3)

        console.log(s5);

    </script>

</body>

</html>

控制台显示:

7.命名规范

变量里面保存的是一份数据,为了方便将来获取里面存储的数据,变量名命名一定要规范。

就是看到变量名就知道里面存储的是什么数据。(见名知意)

在JS中,变量名的规范有:

只能使用:字母、数字、_、$ 做为变量名称。

数字不要开头:例如 var 1a= 100(错误)

不能使用JS的关键字:例如var、let 、const 等关键字,var  var = 100(错误)

多个单词组成的变量名,要使用驼峰命名法,第一个单词的首字母小写,其余单词的首字母大写。

代码:

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>命名规范</title>

</head>

<body>

    <script>

        /*

            变量里面保存的是一份数据,为了方便将来获取里面存储的数据,变量名命名一定要规范。

            就是看到变量名就知道里面存储的是什么数据。(见名知意)

            在JS中,变量名的规范有:

            1.只能使用:字母、数字、_、$ 做为变量名称。

            2.数字不要开头

            3.不能使用JS的关键字

            4.多个单词组成的变量名,要使用驼峰命名法,第一个单词的首字母小写,其余单词的首字母大写。

        */

        var name = '张三'

        console.log(name);

        var name2 = '李四'

        console.log(name2);

        var _age = 20

        console.log(_age);

        var $sex = '女'

        console.log($sex);

        //不是使用js的关键字

        // var var = 100

        //这是规范命名

        var myFirstName = '张'

        console.log(myFirstName);

        //这是不规范命名

        var mylastname = '杰'

        console.log(mylastname);

        //这是不规范命名,变量名要有意义,见名知意

        var abc = '小明'

        console.log(abc);

    </script>

</body>

</html>

控制台显示:

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容

  • 文初先补充两点,数组的排序方式.sort(),括号里面可传函数参数,针对数组里的数据为数字型时,升序的传递函数为f...
    青木樹海阅读 195评论 0 0
  • 11js关系运算符 <!DOCTYPE html> 11js关系运算符 /*关系运算符存在的意义:1、默认情况下,...
    ouyangqinbin阅读 337评论 0 0
  • 01javascript语法规范 <!DOCTYPE html> javascript语法...
    ouyangqinbin阅读 1,304评论 0 0
  • es6中定义变量 通过let 和 const 定义 1. 使用let和const声明的变量,不能重复声明同名变...
    小胖子_d7d8阅读 183评论 0 0
  • 一,JavaScript的书写格式 1.行内脚本:写在HTML标签内部,通过一个属性节点来添加,不推荐使用,例如“...
    刘远舟阅读 459评论 0 0