python_fullstack前端(三)-JavaScript

前端初识

三、前端初识——JavaScript

1、JavaScript语法基础

①变量命名规范
  1. 变量名只能是 字母、数字、下划线或美元符号的任意组合
  2. 变量名不能是数字开头
  3. 关键字不能声明为变量名
  4. 建议用驼峰命名方式
  5. 变量名是区分大小写
  6. 变量的定义要具有可描述性
②变量声明
  • var 变量名 = 变量值;
  • JavaScript属于动态类型(同一个变量可以存不同数据类型的值)
  • 语句必须以分号结束
③注释
  • // 单行注释
  • /*
    多行注释
    */

2、JavaScript数据类型&类型查询

①数字(Number):只有一种数字类型,数字可以带小数点,也可以不带
  • 示例
var a = 12.34;
var b = 20;
var c = 123e5;  # 12300000
var d = 123e-5;  # 0.00123
☆还有一种NaN,表示不是一个数字(Not a Number)
  • 常用方法
# 将字符串转为数字(当传入的字符串参数不能转为数字时,变返回NaN)
parseInt("123")  # 返回123
parseInt("ABC")  # 返回NaN,NaN属性是代表非数字值的特殊值,该属性用于指示某个值不是数字
parseFloat("123.456")  # 返回123.456
②字符串类型(String):字符串可以是引号中的任意文本,可以使用单引号或双引号
  • 示例
var a = "Hello";
var b = 'World';
var c = a + b; 
console.log(c);  # 得到HelloWorld
  • 常用方法
·String.length:返回长度
·String.trim():移除空白
·String.trimLeft():移除左边空白
·String.trimRight():移除右边空白
·String.charAt(n):返回第N个字符
·String.concat(value, ...):拼接字符串
·String.indexOf(substring, start):返回子序列位置
·String.substring(from, to):根据索引获取子序列(顾头不顾尾)
·String.slice(start, end):切片
·String.toLowerCase():转换成小写
·String.toUpperCase():转换成大写
·String.split(delimiter, limit):分割
·string.slice(start, stop)和string.substring(start, stop)对比:
    ·两者的相同点:
        如果start等于end,返回空字符串
        如果stop参数省略,则取到字符串末
        如果某个参数超过string的长度,这个参数会被替换为string的长度
    ·substirng()的特点:
        如果 start > stop ,start和stop将被交换
        如果参数是负数或者不是数字,将会被0替换
    ·silce()的特点:
        如果 start > stop 不会交换两者
        如果start小于0,则切割从字符串末尾往前数的第abs(start)个的字符开始(包括该位置的字符)
        如果stop小于0,则切割在从字符串末尾往前数的第abs(stop)个字符结束(不包含该位置字符)
③布尔类型(Boolean):布尔只能有两个值:true 或 false(注意true和false都是小写)
  • 示例
var x=true;
var y=false;
④数组(Array)
  • 示例
·创建数组方式一:
    var cars=new Array();
    cars[0]="A";
    cars[1]="B";
    cars[2]="C";
·创建数组方式二:
    var cars=new Array("A","B","C");
  • 常用方法
·Array.length:数组的长度
·Array.push(element):尾部追加元素
·Array.pop():获取尾部的元素
·Array.unshift(element):头部插入元素
·Array.shift():头部移除元素
·Array.slice(start, end):切片
·Array.reverse():反转
·Array.join(seq):将数组元素连接成字符串
·Array.concat(val, ...):连接数组
·Array.sort():排序
·关于鸡肋的JavaScript内置sort方法的解释及优化:
    /*
    如果调用sort方法时没有传入参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。
    如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:
    若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
    若 a 等于 b,则返回 0。
    若 a 大于 b,则返回一个大于 0 的值。
    */
    // 根据上面的规则自行实现一个排序函数:
    function sortNumber(a,b) {
      return a - b
    }
    // 调用sort方法时将定义好的排序函数传入即可。
    stringObj.sort(sortNumber)
⑤对象(Object):对象由花括号分隔。在括号内部,对象的属性以名称和值对的形式 (name : value) 来定义。属性由逗号分隔
  • 示例
var person={
firstname : "Elijah",
lastname  : "Yang",
id        :  110104
};
  • 常用寻址方式
name=person.lastname;
name=person["lastname"]; 
⑥空(Null):表示值是空,一般在需要指定或清空一个变量时才会使用
⑦未定义(Undefined):当声明一个变量但未初始化时,该变量的默认值是undefined,函数无明确的返回值时,返回值也是undefined
⑧类型查询
  • 方法:typeof

    • typeof是一个一元运算符(就像++,–,!,- 等一元运算符),不是一个函数,也不是一个语句
  • 规则:

    • undefined - 如果变量是 Undefined 类型的
    • boolean - 如果变量是 Boolean 类型的
    • number - 如果变量是 Number 类型的
    • string - 如果变量是 String 类型的
    • object - 如果变量是一种引用类型或 Null 类型的

3、JavaScript运算符

①算数运算符
  1. +:相加
  2. -:相减
  3. *:相乘
  4. /:相除
  5. %:取余
  6. ++:自加1 (注意:n++表示后自加,++n表示先自加)
  7. –:自减1 (注意:n–表示后自减,–n表示先自减)
②比较运算符
  1. > :大于
  2. >= :大于等于
  3. < :小于
  4. <= :小于等于
  5. == :相等,判断值是否相等
  6. != :不等于
  7. === :严格相等,判断值、类型是否完全相等
  8. !== :严格不等于
③逻辑运算符
  1. && :且
  2. || :或
  3. ! :非
④赋值运算符
  1. = :赋值
  2. += :自加
  3. -= :自减
  4. *= :自乘
  5. /= :自除

4、JavaScript流程控制

①if — else
  • 示例
var a = 10;
if (a > 5){
  console.log("yes");
}else {
  console.log("no");
}
②if — else if — else
  • 示例
var a = 10;
if (a > 5){
  console.log("a > 5");
}else if (a < 5) {
  console.log("a < 5");
}else {
  console.log("a = 5");
}
③switch
  • 示例
var day = new Date().getDay();
switch (day) {
  case 0:
  console.log("Sunday");
  break;
  case 1:
  console.log("Monday");
  break;
default:
  console.log("...")
}       
  • 注意:switch中的case子句通常都会加break语句,否则程序会继续执行后续case中的语句
④for
  • 示例
for (var i=0;i<10;i++) {
  console.log(i);
}
⑤while
  • 示例
var i = 0;
while (i < 10) {
  console.log(i);
  i++;
}
⑥三元运算:判断条件?满足条件的返回值:不满足条件的返回值
  • 示例
var a = 1;
var b = 2;
var c = a > b ? a : b

5、JavaScript函数

①函数定义
  • 普通函数定义
function func1() {
    console.log('hello world!');
}
  • 带参数的函数定义
function func1(arg1,arg2){
    console.log('arg1:',arg1);
    console.log('arg2:',arg2);
}
  • 带返回值的函数定义
function func1(arg1,arg2){
    return arg1+arg2;
}
fun1(1,2); //函数调用
  • 匿名函数定义
var foo= function(arg1,arg2){
    return arg1+arg2;
}
foo(1,2) //函数调用
  • 立即执行函数定义
(function(arg1,arg2){
    return arg1+arg2;
})(1,2);
②类数组对象arguments
  • 作用

    • Javascript并没有重载函数的功能,但是通过Arguments对象能够模拟重载。
    • Javascript的每个函数都会有一个Arguments对象实例arguments,它引用着函数的实参,它也有类似于数组的length属性。
      1. arguments.length 为函数实参个数。
      2. arguments.callee 引用函数自身。
  • 示例

function func2(a,b) {
    console.log("总共有" + arguments.length + "个参数");
    var ret = 0;
    for (var i=0;i<arguments.length;i++){
        ret += arguments[i]
    }
    return ret;
}
console.log(func2(11,22,33));
③局部变量&全局变量
  • 局部变量:

    • 在JavaScript函数内部声明的变量(使用 var)是局部变量,所以只能在函数内部访问它(该变量的作用域是函数内部)
    • 只要函数运行完毕,本地变量就会被删除。
  • 全局变量:

    • 在函数外声明的变量是全局变量,网页上的所有脚本和函数都能访问它。
  • 变量生存周期:

    • JavaScript变量的生命期从它们被声明的时间开始。
    • 局部变量会在函数运行以后被删除。
    • 全局变量会在页面关闭后被删除。
④作用域:首先在函数内部查找变量,找不到则到外层函数查找,逐步找到最外层。
  • 示例1
var city = "BeiJing";
function f() {
  var city = "ShangHai";
  function inner(){
    var city = "ShenZhen";
    console.log(city);
  }
  inner();
}
f();  

结果:
"ShenZhen"
  • 示例2
var city = "BeiJing";
function Bar() {
  console.log(city);
}
function f() {
  var city = "ShangHai";
  return Bar;
}
var ret = f();
ret(); 

结果:
"BeiJing"
  • 示例3:闭包
var city = "BeiJing";
function f(){
    var city = "ShangHai";
    function inner(){
        console.log(city);
    }
    return inner;
}
var ret = f();
ret();

结果:
"ShangHai" 

6、词法分析:JavaScript中在调用函数的那一瞬间,会先进行词法分析。

①词法分析的过程
  • 当函数调用的前一瞬间,会先形成一个激活对象:Avtive Object(AO),并会分析以下3个方面:
    • 函数参数,如果有,则将此参数赋值给AO,且值为undefined。如果没有,则不做任何操作。
    • 函数局部变量,如果AO上有同名的值,则不做任何操作。如果没有,则将此变量赋值给AO,并且值为undefined。
    • 函数声明,如果AO上有,则会将AO上的对象覆盖。如果没有,则不做任何操作。
②注意:函数内部无论是使用参数还是使用局部变量都到AO上找。
③示例1
var age = 18;
function foo(){
  console.log(age);
  var age = 22;
  console.log(age);
}
foo();  

结果:
undefined
22
④示例2
var age = 18;
function foo(){
  console.log(age);
  var age = 22;
  console.log(age);
  function age(){
    console.log("呵呵");
  }
  console.log(age);
}
foo();

结果:
function age()
22
22

词法分析过程:
1、分析参数,有一个参数,形成一个 AO.age=undefine;
2、分析变量声明,有一个 var age, 发现 AO 上面已经有一个 AO.age,因此不做任何处理
3、分析函数声明,有一个 function age(){...} 声明, 则把原有的 age 覆盖成AO.age=function(){...};
最终,AO上的属性只有一个age,并且值为一个函数声明

执行过程:
注意:执行过程中所有的值都是从AO对象上去寻找
1、执行第一个 console.log(age) 时,此时的 AO.age 是一个函数,所以第一个输出的一个函数
2、这句 var age=22; 是对 AO.age 的属性赋值, 此时AO.age=22 ,所以在第二个输出的是 2
3、同理第三个输出的还是22, 因为中间再没有改变age值的语句了

7、JavaScript内置对象&方法

①介绍
  • JavaScript中的所有事物都是对象:字符串、数字、数组、日期,等等。在JavaScript中,对象是拥有属性和方法的数据。
  • 我们在学习基本数据类型的时候已经带大家了解了,JavaScript中的Number对象、String对象、Array对象等。
  • 注意:var s1 = “abc”和var s2 = new String(“abc”)的区别:typeof s1 –> string而 typeof s2 –> Object
类型内置对象介绍
数据类型Number数字对象
数据类型String字符串对象
数据类型Boolean布尔值对象
组合对象Array数组对象
组合对象Math数学对象
组合对象Date日期对象
高级对象Object自定义对象
高级对象Error错误对象
高级对象Function函数对象
高级对象RegExp正则表达式对象
高级对象Global全局对象
②自定义对象
  • 创建、访问自定义对象
//方式一:
var a = {"name": "Yang", "age": 18};
console.log(a.name);
console.log(a["age"]);

//方式二:
var person=new Object();  // 创建一个person对象
person.name="Yang";  // person对象的name属性
person.age=18;  // person对象的age属性
  • 遍历对象中的内容:
var a = {"name": "Yang", "age": 18};
for (var i in a){
  console.log(i, a[i]);
}
  • JavaScript面向对象之继承(扩展)
// 父类构造函数
var Car = function (loc) {
  this.loc = loc;
};

// 父类方法
Car.prototype.move = function () {
  this.loc ++;
};

// 子类构造函数
var Van = function (loc) {
  Car.call(this, loc);
};

// 继承父类的方法
Van.prototype = Object.create(Car.prototype);
// 修复 constructor
Van.prototype.constructor = Van;
// 扩展方法
Van.prototype.grab = function () {
  /* ... */
};
③Date对象
  • 创建Date对象
//方法1:不指定参数
var d1 = new Date();
console.log(d1.toLocaleString());

//方法2:参数为日期字符串
var d2 = new Date("2008/8/8 20:08");
console.log(d2.toLocaleString());
var d3 = new Date("08/8/8 20:08");
console.log(d3.toLocaleString());

//方法3:参数为毫秒数
var d3 = new Date(5000);
console.log(d3.toLocaleString());
console.log(d3.toUTCString());

//方法4:参数为年月日小时分钟秒毫秒
var d4 = new Date(2008,8,8,20,08,08,100);
console.log(d4.toLocaleString());  //毫秒并不直接显示
  • Date对象的方法
var d = new Date(); 
//getDay ()              获取当前星期X(0-6,0代表星期天)
//getMonth ()            获取当前月份(0-11,0代表1月)
//getFullYear ()         获取完整的年份(4位,1970-????)
//getYear ()             获取当前年份(2位)
//getHours ()            获取当前小时数(0-23)
//getMinutes ()          获取当前分钟数(0-59)
//getSeconds ()          获取当前秒数(0-59)
//getMilliseconds()      获取当前毫秒数(0-999)
//getTime ()             返回累计毫秒数(从1970/1/1午夜)
//toLocaleDateString();  获取当前日期
//toLocaleTimeString();  获取当前时间
//toLocaleString( );     获取日期与时间
④JSON对象
  • JSON对象方法示例
var str1 = '{"name": "Yang", "age": 18}';
var obj1 = {"name": "Yang", "age": 18};
// JSON字符串转换成对象
var obj = JSON.parse(str1); 
// 对象转换成JSON字符串
var str = JSON.stringify(obj1);
⑤RegExp对象
  • 创建方法
    • 创建方法一
// 创建RegExp对象方式(逗号后面不要加空格)
var reg1 = new RegExp("^[a-zA-Z][a-zA-Z0-9_]{5,11}$");
// 匹配响应的字符串
var s1 = "abc123";
//RegExp对象的test方法,测试一个字符串是否符合对应的正则规则,返回值是true或false。
reg1.test(s1);  // true
  • 创建方法二
// 匹配响应的字符串
var s1 = "abc123";
// /填写正则表达式/匹配模式(逗号后面不要加空格)
var reg2 = /^[a-zA-Z][a-zA-Z0-9_]{5,11}$/.test(s1);  // true
  • 示例
// String对象与正则结合的4个方法
var s2 = "hello world";
s2.match(/o/g);         // ["o", "o"]             查找字符串中 符合正则 的内容
s2.search(/h/g);        // 0                      查找字符串中符合正则表达式的内容位置
s2.split(/o/g);         // ["hell", " w", "rld"]  按照正则表达式对字符串进行切割
s2.replace(/o/g, "s");  // "hells wsrld"          对字符串按照正则进行替换

// 关于匹配模式:g和i的简单示例
var s1 = "name:Adele age:18";

s1.replace(/a/, "替换");      // "n替换me:Adele age:18"
s1.replace(/a/g, "替换");     // "n替换me:Adele 替换ge:18"      全局匹配
s1.replace(/a/gi, "替换");    // "n替换me:替换dele 替换ge:18"   不区分大小写
  • RegExp对象使用时的几点注意事项
    1. 正则表达式(不能有空格)
    2. 匹配模式:常用g(全局匹配;找到所有匹配,而不是在第一个匹配后停止)和i(忽略大小写)
    3. 如果regExpObject带有全局标志g,test()函数不是从字符串的开头开始查找,而是从属性regExpObject.lastIndex所指定的索引处开始查找。该属性值默认为0,所以第一次仍然是从字符串的开头查找。当找到一个匹配时,test()函数会将regExpObject.lastIndex的值改为字符串中本次匹配内容的最后一个字符的下一个索引位置。当再次执行test()函数时,将会从该索引位置处开始查找,从而找到下一个匹配。因此,当我们使用test()函数执行了一次匹配之后,如果想要重新使用test()函数从头开始查找,则需要手动将regExpObject.lastIndex的值重置为 0。如果test()函数再也找不到可以匹配的文本时,该函数会自动把regExpObject.lastIndex属性重置为 0。
    4. 当我们不加参数调用RegExpObj.test()方法时, 相当于执行RegExpObj.test(“undefined”), 并且/undefined/.test()默认返回true
⑥Math对象
  • Math对象方式介绍
对象名介绍
abs(x)返回数的绝对值。
exp(x)返回 e 的指数。
floor(x)对数进行下舍入。
log(x)返回数的自然对数(底为e)。
max(x,y)返回 x 和 y 中的最高值。
min(x,y)返回 x 和 y 中的最低值。
pow(x,y)返回 x 的 y 次幂。
random()返回 0 ~ 1 之间的随机数。
round(x)把数四舍五入为最接近的整数。
sin(x)返回数的正弦。
sqrt(x)返回数的平方根。
tan(x)返回角的正切。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值