前端开发—Javascript

Javascript

 

 

  语言简介:

    

  语言规范:

    注释:/  这是单行注释 /   /* 换行*/ 多行注释

    结束符: ;分号

 

语法基础

 

    

变量

  变量声明

    1 变量名可以是 数字 字母 下划线 $ 组成,不能以数字开头。

    2 声明变量使用 var 或 let 。

    3 推荐使用驼峰体。

    4 声明常量:const

 

数据类型

    1 JS 拥有动态类型,声明之后的变量名支持不同数据类型的切换。查看数据类型 typeof()

    Number(数值)  js 不区分整数与浮点数,NaN 代表不是一个数字,它也是数值类型。

    String(字符串)字符串的拼接推荐使用+,数字和字符串也可以拼接,是将数值转换为字符串后再将两个值左        拼接。单行文本用 单引号,多行文本用esc下方的键。

        

字符串拼接,${变量名}  注意{}的变量名必须事先定义好。
var
name1 = 'agon'; var age =84; var res =` my name is ${name1} my age is %{age} `
var name1='babao';
name1.split('a');
(3) ["b", "b", "o"]  
name1.split('a',1);
["b"] 可以通过第二个参数控制想要切片之后的数据个数,默认从做到右取。

substring 切片与 slice 切片的区别,slice识别负数,而substring不支持。
var name2='  babao   ';
undefined
name2.length;  /字符串长度/
10
name2.trim();  /移除空白/
"babao"
name2.trimRight();  /移除右边空白/
"  babao"
name2.trimLeft();   /移除左边空白/
"babao   "
name2.concat('123','456');  /连接两个或多个数组,并返回拼接结果/
"  babao   123456"
name2.indexOf('a');  /获取 ‘a’ 的索引位置/
3

 

      字符串方法:

方法说明
.length返回长度
.trim()移除空白
.trimLeft()移除左边的空白
.trimRight()移除右边的空白
.charAt(n)返回第n个字符
.concat(value, ...)拼接
.indexOf(substring, start)子序列位置
.substring(from, to)根据索引获取子序列
.slice(start, end)切片
.toLowerCase()小写
.toUpperCase()大写
.split(delimiter, limit)分割

    Boolean(布尔类型)true false 注意是小写。

      '' (空字符串)、0、null、underfined、NaN 都是false。

    Undefined(未定义的值) 没有被赋值的变量。 

    Null(没有对象)   

      null表示值是空,一般在需要指定或清空一个变量时才会使用,如 name=null;

      undefined表示当声明一个变量但未初始化时,该变量的默认值是undefined。还有就是函数无明确的返回值时,返回的也是undefined。

      null表示变量的值是空(null可以手动清空一个变量的值,使得该变量变为object类型,值为null),undefined则表示只声明了变量,但还没有赋值。

对象(object)

    JS中一切皆对象:字符串、数值、数组、函数、js允许自定义对象。       

数组

    数组对象的作用是:使用单独的变量名来存储一系列的值。类似于Python中的列表。

    常用方法:

    

方法说明
.length数组的大小
.push(ele)尾部追加元素
.pop()获取尾部的元素
.unshift(ele)头部插入元素
.shift()头部移除元素
.slice(start, end)切片
.reverse()反转
.join(seq)将数组元素连接成字符串
.concat(val, ...)连接数组
.sort()排序
.forEach()将数组的每个元素传递给回调函数
.splice()删除元素,并向数组添加新元素。
.map()返回一个数组元素调用函数处理后的值的新数组

运算符

  > >= < <= != == === !==

  5==‘5’ 结果 true  弱等于,js会内部自动转换数据类型。5===‘5’ 强等于,正常的等于。

  

var x=10;
var res1=x++;
var res2=++x;
    res1;
    10
    res2;
    12

      ++赋值运算符,x++,先赋值再自增
      ++x 先自增再赋值

逻辑运算符

  && (and 与) || (or 或)   ! (not 非)

赋值预算法

  = += -= *= /=

流程控制

  if-else  else if

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("...")
}

  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
//这里的三元运算顺序是先写判断条件a>b再写条件成立返回的值为a,条件不成立返回的值为b;三元运算可以嵌套使用;

var a=10,b=20;
var x=a>b ?a:(b=="20")?a:b;

x
10

 

内置方法

 

 

   map() 反射

  

 

参数描述
function(currentValue, index,arr)必须。函数,数组中的每个元素都会执行这个函数
函数参数:
参数描述
currentValue必须。当前元素的值
index可选。当期元素的索引值
arr可选。当期元素属于的数组对象
thisValue可选。对象作为该执行回调时使用,传递给函数,用作 "this" 的值。
如果省略了 thisValue ,"this" 的值为 "undefined"
var l1=[11,55,444,44,77];

l1.map(function (values,index,arr) {
    return values+1
    
});

(5) [12, 56, 445, 45, 78]

   splice()  向/从数组中添加/删除项目,然后返回被删除的项目。 

        注意:该方法会改变原来的数组。 

  
    

  sort() 排序

关于sort()需要注意:

如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。

如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:

若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
若 a 等于 b,则返回 0。
若 a 大于 b,则返回一个大于 0 的值。

function
sortNumber(a,b){ return a - b } var arr1 = [11, 100, 22, 55, 33, 44] arr1.sort(sortNumber) (6) [11, 22, 33, 44, 55, 100]

 

  

 

函数

 

 

// 普通函数定义
function f1() {
  console.log("Hello world!");
}

// 带参数的函数
function f2(a, b) {
  console.log(arguments);  // 内置的arguments对象
  console.log(arguments.length);
  console.log(a, b);
}

// 带返回值的函数
function sum(a, b){
  return a + b;
}
sum(1, 2);  // 调用函数

// 匿名函数方式
var sum = function(a, b){
  return a + b;
}
sum(1, 2);

// 立即执行函数 书写立即执行的函数,首先先写两个括号()()这样防止书写混乱
(function(a, b){
  return a + b;
})(1, 2);

 

  补充:

   ES6 中允许使用‘箭头’(=>)定义函数。 

var f = v => v;
// 等同于
var f = function(v){
  return v;
}

 

  如果箭头函数不需要参数或需要多个参数,就用小括号代表参数部分:

var f = () => 5;
// 等同于
var f = function(){return 5};

var sum = (num1, num2) => num1 + num2;
// 等同于
var sum = function(num1, num2){
  return num1 + num2;  //这里的return只能返回一个值,如果想返回多个值需要自己手动给他们包一个数组或对象中
}

 

函数中的arguments参数

 

转载于:https://www.cnblogs.com/guanchao/p/10957099.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值