JS基础简介

JS基础简介

一、JS简介

   JavaScript(简称'js')是一种具有函数优先的轻量级、解释型或及时编译型的编程语言。虽然它是作为开发web页面的脚本语言而出名,但是它也被用到了很多的非浏览器环境中,JS基于原型编程,多范式的动态脚本语言,并且支持面向对象、命令式、声明式、函数式编程范式。
   JavaScript在1995年由Netscape公司的Brendan Eich,在网景导航者浏览器上首次设计实现而成。因为Netscape与Sun合作,Netscape管理层希望它外观看起来像Java,因此取名为JavaScript。但实际上它的语法风格与Self及Scheme较为接近。
    JavaScript的标准是ECMAScript 。截至 2012 年,所有浏览器都完整的支持ECMAScript 5.1,旧版本的浏览器至少支持ECMAScript 3 标准。2015年6月17日,ECMA国际组织发布了ECMAScript的第六版,该版本正式名称为 ECMAScript 2015,但通常被称为ECMAScript 6 或者ES2015。
主要功能:
嵌入动态文本于HTML页面。 
对浏览器事件做出响应。 
读写HTML元素。  
在数据被提交到服务器之前验证数据。 
检测访客的浏览器信息。控制cookies,包括创建和修改等。  
基于Node.js技术进行服务器端编程。 
语言组成:
ECMAScript,描述了该语言的语法和基本对象。 
文档对象模型(DOM),描述处理网页内容的方法和接口。 
浏览器对象模型(BOM),描述与浏览器进行交互的方法和接口。 

img

​ # 图JavaScript生成器和迭代器(了解)

二、JS基础

1.js的引入方式

1.在head内script标签内编写
  <script> js代码</script>
2.在head内script属性引入外部的js属性
   <script src='my.js'> </script>
3.body内最底部通过script标签src属性引入外部js属性(最常用)
ps:注意页面的下载是从上往下的 所以操作标签js代码一定要等待标签加载完毕再执行才可以正常运行

2.基本语法

1.注释语法
  //  单行注释
  /**/  多行注释
2.结束符号
  分号(;) 很多时候不写也可以

3.变量与常量

js的变量名可以使用数字,字母,下划线,$等组成,不能以数字开头
1.var:声明是全局变量,全局有效
    var name = 'jason'
2.let:声明是局部的,只在局部名称空间有效
    let name = 'jia'
3.常量声明:常量时不可以重新绑定数据值
    const pi = 3.14
# 注意:
1.变量名是区分大小写的
2.推荐使用驼峰式命名规则
3.保留字不能用作变量名
4.js是动态类型,变量名绑定的数据值类型不固定

三、基本数据类型

1.数值类型(包括了整型和浮点型)

js不分整型和浮点型,就只有一种数字类型,即所有的数值都是数字类型
在js中查看数据类型的方法:typeof
1.js中只有数字一种类型
 var a = 12.33    #  typeof(a) ---> 'number'
 var b = 12       #  typeof(b) ---> 'number'
 var c = 12e4     #  typeof(c) ---> 'number'
 var d = 12e-4    #  typeof(d) ---> 'number'
2.NaN是一个特殊的数字,表示Not A Number,不是一个数字
    parseInt("12")        # 12
    parseInt("12.33")     # 12
    parseFloat('12.35')   # 12.35
    parseInt("ABC")       # NaN

2.字符串类型

默认是使用单引号和双引号,模板字符串是增强版的字符串,用反引号(``)标识,它可以当做普通字符串使用,也可以用来定义多行字符串,或者在字符串中嵌入变量。
1.字符串拼接(使用+号拼接)
var h1 = '今天吃到了娟带的大虾,很好吃,也很开心'
var h2 = '今天和好几天没见的薇薇抱了一下,真开心,有这些朋友在身边,是最幸福的事情'
var h3 = h1 + h2
'今天吃到了娟带的大虾,很好吃,也很开心今天和好几天没见的薇薇抱了一下,真开心,有这些朋友在身边,是最幸福的事情'

2.统计长度(length)
h3.length  -----> 55

3.移除空白
var h4 = '   以后有什么事情自己消化,不要全部倾诉给他,他也会烦的,记住!   '
h4.trim()     # 移除两边的空白字符
'以后有什么事情自己消化,不要全部倾诉给他,他也会烦的,记住!'
h4.trimLeft()   # 移除左边的空白字符
'以后有什么事情自己消化,不要全部倾诉给他,他也会烦的,记住!   '
h4.trimRight()   # 移除右边的空白字符
'   以后有什么事情自己消化,不要全部倾诉给他,他也会烦的,记住!'

4.切片操作
js中使用substring(start,stop),slice(start,stop)切片,前者不支持负数索引,后者支持
var h5 = '好好努力,精神独立,经济独立,改掉对别人的依赖,独立,自强。'
h5.substring(1,10)
'好努力,精神独立,'
h5.slice(4,19)
',精神独立,经济独立,改掉对别'
h5.slice(1,-17)
'好努力,精神独立,经济独'
h5.slice(-1,10)      
''                      # 支持负数索引,但是不支持倒着切

5.大小写转换
js中使用toLowerCase(),toUpperCase()转大小写
var s1 = 'abCD'
undefined
s1.toUpperCase()
'ABCD'
s1.toLocaleUpperCase()
'ABCD'

6.切割字符串
js 中使用split对字符串进行切割
h6.split('')
(6) ['1', '2', '3', '4', '5', '6']
.split(splitter,limit)-->(splitter;按照什么分割,limit:分割后返回完成后的列表中的几个数据(从左往右))

7.字符串的格式化
js中使用格式化字符串(小顿号esc下面的那个键搭配${}使用)
var h7 = '现在就只有一件事,好好学习,每天做好预习复习,充实每一天,别再把心思放在无关的事情上啦!'
var h8 = 'ヾ(◍°∇°◍)ノ゙'
console.log(`my target is ${h7} and ${h8}`);
VM3675:1 my target is 现在就只有一件事,好好学习,每天做好预习复习,充实每一天,别再把心思放在无关的事情上啦! and ヾ(◍°∇°◍)ノ゙

8.布尔类型(boolean)
js --->布尔值:true,false
false ---> ""(空字符串),0,null,NaN,underfined
Python --->布尔值:True,False
false ---> ""(空字符串),0,None,空字符串,空列表,空字典
var h9 = 123
var h10
Boolean(h9)  ----> true
Boolean(h10) ----> false

9.null和undefined
null表示值为空(就是曾经拥有过)
undefined表示没有定义(从来没有过)

10.数组(array)
在python中叫列表,在其它编程语言里几乎都叫数组。

11.对象(object)
js中一切皆对象
对象之自定义对象(Object)>>>:类似于python的字典
let h11 = {'name' : 'jia','pwd' : 123}
typeof h11    ---> 'object'
let d2 = new Object()
typeof d2     ---> 'object'
h11['name']
'jia'
h11.name
'jia'
h11.name = 'jason'
'jason'
js中的方法 js中的说明 VS Python中的方法 Python中的说明
.length() 数组大小 .len() 统计列表中数据值的个数
.push(ele)() 尾部追加元素 .append() 尾部追加元素(insert:指定位置插入,extend:扩展列表)
.pop() 获取尾部的元素 .pop() 删除尾部的数据值
.unshift(ele)() 头部插入元素 .insert() 指定位置插入(可以利用索引在头部插入元素)
.shift() 头部移除元素 .remove() 利用索引移除头部元素
.slice() 切片 [,] 索引切片
.reverse() 反转 .reverse() 将列表中的数据从右往左反转
.join() 将数组元素拼接成字符串 .join() 拼接列表的元素
.concat() 连接数组 .extend() 扩展列表
.sort() 排序 .sort() 默认升序
.forEach() 将数组的每个元素传递给回调函数
.splice() 删除元素,并向数组添加新元素
.map() 返回一个数组元素调用函数处理后的值的新数组 map映射 内置函数,老数据值变成新的数据值

四、常见运算符

1.算术运算符
+ - * / % ++(递加) --(递减) **(幂)
var s = 10
var s1 = s++;   # 先赋值再自增1   10
var s2 = ++s    # 先自增1再赋值   12

2.赋值运算符
=  +=  -=  *=  /=  %=

3.比较运算符
==(等于,弱)  ===(等值等型,强)  !==(值不等 弱)  !===(值不等 强) 
'5' == 5  ---->  true  'js会自动转换成相同的数据类型比较值是否一样'
'5' === 5  ---->  false
# 上面这种情况出现的原因在于JS是一门弱类型语言(会自动转换数据类型),所以当你用两个等号进行比较时,JS内部会自动先将数值类型的1转换成字符串类型的1再进行比较,所以我们以后写JS涉及到比较时尽量用三等号来强制限制类型,防止判断错误。

4.逻辑运算符
&&(与)   ||(或)    !(非)
5.类型运算符
typeof()  # 返回变量的类型

五、流程控制

1.单if分支
if(条件){
    条件成立执行的代码
}
2.if....else分支
if(条件){
    条件成立执行的代码
}else{
    条件不成立执行的代码
}
3.if....else if...else分支
if(条件1){
    条件1成立执行的代码
}else if(条件2){
    条件2成立执行的代码
}else{
    条件1,2都不成立执行的代码
}
4.如果分支结构中else if很多还可以考虑switch语法
switch(条件){
    case 条件1:
         条件1成立时执行的代码;
         break;  # 没有这个break会基于某个case一直在想下去
    case 条件2:
         条件2成立时执行的代码;
         break;
    case 条件3:
         条件3成立时执行的代码;
         break;
    case 条件4:
         条件4成立时执行的代码;
         break;
    default:
         条件都不满足执行的代码
}
5.for循环:
for(起始条件;循环条件;条件处理){
    循环体代码
}
6.while循环:
while(循环条件){
    循环体代码
}
7.三元运算
python :  值1 if 条件 else 值2
js:    条件?值1:值2
eg:
2 > 3 ? '你好':'侬好'
'侬好'    

六、函数

语法:
function 函数名(形参){
    //函数注释
    函数体代码
    return 返回值
}
# 匿名函数
var l1 = function(a,b){
    return a+b
}
# 箭头函数
var f = v =>v;
var f=function(v){
    return v
}
'''
python 中函数的定义:
def 函数名(形参):
    '''函数注释'''
    函数体代码
    return 返回值
'''
1.js函数体代码中的形参与实参可以不对应
    传少了就是undefined 传多了不用
2.函数体代码中有一个关键字arguments用来接收所有的实参
3.函数的返回值如果有多个需要自己处理成一个整体

七、内置函数

var d = new Date()
Mon Dec 05 2022 20:37:27 GMT+0800 (中国标准时间)
console.log(d.toDateString())
VM4784:1 Mon Dec 05 2022
d.getDate()       # 获取日  
5
d.getDay()         #获取星期
1
d.getMonth()       # 获取月(0-11)
11
d.getFullYear()     # 获取完整年份
2022
d.getYear()         # 获取年
122
d.getHours()        # 获取小时
20
d.getMinutes()      # 获取分钟
37
d.getSeconds()      # 获取秒
27
d.getMilliseconds()    # 获取毫秒
755
d.getTime()            # 返回累计毫秒数(从1970/1/1午夜)
1670243847755

八、序列化与反序列化

在JSON中序列化:
JSON.stringify()  # 将数值转换为JSON格式
JSON.parse()  # 将JSON格式转换为原来的格式
eg:
let d9 = {name:'jia',age:18}
undefined
JSON.stringify(d9)
'{"name":"jia","age":18}'
let ss = '{"name":"jia","age":18}'
undefined
JSON.parse(ss)
{name: 'jia', age: 18}

九、正则表达式

# 创建正则表达式的两种方式
var reg1 = new RegExp("^[a-zA-Z][a-zA-Z0-9]{5,11}");
var reg2 = /^[a-zA-Z][a-zA-Z0-9]{5,9}$/;  # 推荐使用(简化)
全局匹配:在正则表达式的最后添加一个字母g
var reg2 = /^[a-zA-Z][a-zA-Z0-9]{5,9}$/g;
posted @ 2022-12-05 20:48  小王应该在学习!  阅读(340)  评论(0编辑  收藏  举报