javascript 跳跃式前进 (1) - 基本概念

简介: javascript 是弱类型语言,比较接近python和perl这类,不如java和c那样严格.所以写惯了强类型语言的小伙伴看到有些另类的写法也相当正常;有些东东不精讲..以后单独脱离出来细讲;


原文链接: blog.csdn.net


前言


javascript 是弱类型语言,比较接近python和perl这类,不如java和c那样严格.所以写惯了强类型语言的小伙伴看到有些另类的写法也相当正常;


有些东东不精讲..以后单独脱离出来细讲;


要点提取:


语法


  1. 区分大小写[非常重要哦,比如True和False就不是布尔值了,而是标示符]
  2. 和强类型基本大同小异,以强类型的命名风格基本没什么错误;推荐驼峰大小写
  3. 注释有单行和多行注释
  4. 严格模式,速度运行是最快的;但是相当多的东西给限制了
  5. 语句以分号结尾,支持多变量定义[逗号隔开],在语句多的时候,链式写法速度有一定的速度提升;
  6. 关键字和保留字不允许来做变量名[具体查表去吧..很多]


数据类型


有这么些数据类型: undefined(未定义) , Null(空值 – 特殊值) , Boolean(布尔值) , Number(数值) , String(字符串) , Object(对象,这个范围挺广,Array也属于其中),symbol[ES6]


  • undefined : 变量未初始化的默认值
  • null : 是一个特殊的对象[空的对象引用]
  • boolean : 只有true和false两个值,值得注意的是0和1不一定代表false和true
  • Number : js没有双精度.只有单精度..也不像强类型语言,根据是否有小数点且跟值来定义浮点还是整数 , 数值溢出为infinity,[NaN是一个特殊的数值]
  • String : 字符串
  • Object : 函数就是对象..在JS中函数在没有返回值时默认返回的一个对象
  • Symbol : 这个是ES6才加入的,笼统点的说就是特殊的标示符,可以用来区别某些实例或者对象;但不等同于lisp那样的symbol(具体我现在也没深入~~~)


数据判断


typeof , instanceof , hasOwnProperty, isPrototypeOf ,isArray


  • typeof : 会把大多类型归为对象
  • instanceof : 用于判断一个变量是否某个对象的实例
  • hasOwnProperty:是用来判断一个对象是否有你给出名称的属性或对象。不过需要注意的是,此方法无法检查该对象的原型链中是否具有该属性,该属性必须是对象本身的一个成员。
  • isPrototypeOf: 是用来判断要检查其原型链的对象是否存在于指定对象实例中,是则返回true,否则返回false。
  • isArray : ES5添加专门判断是否为数组的


数据转换


  • Number() : 可以把允许转换成数值的内容变成数值,比如字符串”123”[前置0会忽略],空字符串为0,除能转为数字格式外的字符都会转为NaN
  • paseInt() : 转换字符串为整数,若是”111ee”只会得到111,逐个字符遍历的[若是非数字开头则不会遍历,遇到小数点也会停止]..
  • parseFloat() : 转换字符串为浮点数,与上面那个类似
  • Boolean() : 转为布尔值
  • String() : 把值转为字符串,对象转换会调用ValueOf(),与toString()效果基本一致


操作符


  • 一元操作符 : 包括加减乘除,前置减减加加和后置减减加加[前置先赋值生效再执行,后置执行后再运算]
  • 按位操作符 : 跟强类型语言一致,包括按位非(~)[值的反值,真假调换],按位与(&)[同为真才为真,其他为假],按位或(|)[存真即为真,同假才假],按位异或(^)[相同为假,不同为真]
  • 左移和右移: 左移为乘以2的次幂,右移除以2的次幂..无符号右移[正数不变,符号会因为左边填充0变成一个相当大的正值]
  • 逻辑运算符 : 逻辑与(&&)[同为真才为真,其他为假] ,逻辑或(||)[有真即为真,同假才为假]
  • 相等操作符 : = [赋值,有复合操作符(可以配合加减乘除求余等运算符 ,例如 a %= 3 , b *= 2;)] , == [若允许转换成比较的类型,自动转换匹配的类型比较] , === [强等,不转换比较,同时比较类型和值]
  • 条件运算符[三目运算符] : (expression)? true : false ; 表达式真假来获取对应的返回值


流控制语句


流控制语句,,大多编程语言都是大同小异~~~~


//推荐带花括号,且花括号左边紧贴表达式,可以降低语法解析识别为错误的问题[解析器会自动给一些变量或者语句添加分号]
if(conditions) {
  ...
 }else if{
 ...
}else{
 ...
}


//先执行do里面的逻辑,再执行判断表达式来确定下一步是否执行
  do{
   statement;
  }while(expression)


//适合不知道应该循环多少次的,符合条件就无限执行,带花括号是一个好习惯
   while(expression){
     statement;


//适合有限的循环
 for(initialization ; expression ; post-loop-expression){
    statement;


//[ES5]适合来枚举对象的属性,遇到值为null或者undefined则会抛出错误
   for(proerty in expression){
        statement;
   }


//[ES5] 适合遍历数组,缺点:不能用break跳出循环和用return语句
 //传统是用for来遍历数组...见仁见智哈
var arr = [1,2,3,4];
arr.forEach(function(value){console.log(value)})
//结果集: 1,2,3,4,undefined


//[ES6]这货的出现,更加方便了数组的遍历...
   //它避免了for-in的所有缺陷;
   //与forEach()不一样,它支持break,continue和return。
   var arr = [1,2,3,4];  
   for(var i of arr){
       console.log(i)
   }
   //结果集: 1,2,3,4,undefined


//跟goto好类似....一般配合break和continue语句;在多重嵌套循环的时候,可以满足条件直接跳出整个循环(标签指定的位置)
   label : for(initialization ; expression ; post-loop-expression){
    statement;


//break是跳出循环(中断执行)
    //continue是跳出这次循环,进入下一次循环(只是跳过符合条件的那一次循环,会继续执行到结束)   


//语法和高级编程语言大同小异,适合多重判断(当然不嫌弃麻烦可以用if..elseif...else)
   //小提示.若不是要执行多个表达式..记得每个对应判断条件后必须break结束;否则会依次往下寻找对应的值,其上的所有非包含break的都会执行;
   switch(expression){
        case value1 : statement; break;  
        case value2 : statement; break;  
        case value3 : statement; break;  
         ...
        default:statement;break;
 }


函数


/*
    与大多编程语言一样..函数执行到return语句就结束该函数了..不管后面还有木有表达式;
     因为JS是弱类型语言..  在ES6前,有些东西不得不模拟,比如匿名函数,闭包,"花样式"继承  
     有点值得一提的是,,JS木有重载(当前,以后就不晓得会不会增加)
     这里不多说..到时候在新文章拖出来细细揣摩
*/
    function say(){
          console.log("Hello world!");
    }
    say();
    function say1(args1,args2){
          console.log("Hello world!");
    }
    say1();
目录
相关文章
|
1月前
|
机器学习/深度学习 自然语言处理 JavaScript
信息论、机器学习的核心概念:熵、KL散度、JS散度和Renyi散度的深度解析及应用
在信息论、机器学习和统计学领域中,KL散度(Kullback-Leibler散度)是量化概率分布差异的关键概念。本文深入探讨了KL散度及其相关概念,包括Jensen-Shannon散度和Renyi散度。KL散度用于衡量两个概率分布之间的差异,而Jensen-Shannon散度则提供了一种对称的度量方式。Renyi散度通过可调参数α,提供了更灵活的散度度量。这些概念不仅在理论研究中至关重要,在实际应用中也广泛用于数据压缩、变分自编码器、强化学习等领域。通过分析电子商务中的数据漂移实例,展示了这些散度指标在捕捉数据分布变化方面的独特优势,为企业提供了数据驱动的决策支持。
63 2
信息论、机器学习的核心概念:熵、KL散度、JS散度和Renyi散度的深度解析及应用
|
5月前
|
设计模式 JavaScript 前端开发
在JavaScript中,继承是一个重要的概念,它允许我们基于现有的类(或构造函数)创建新的类
【6月更文挑战第15天】JavaScript继承促进代码复用与扩展,创建类层次结构,但过深的继承链导致复杂性增加,紧密耦合增加维护成本,单继承限制灵活性,方法覆盖可能隐藏父类功能,且可能影响性能。设计时需谨慎权衡并考虑使用组合等替代方案。
46 7
|
1月前
|
设计模式 JavaScript 前端开发
探索JavaScript中的闭包:从基础概念到实际应用
在本文中,我们将深入探讨JavaScript中的一个重要概念——闭包。闭包是一种强大的编程工具,它允许函数记住并访问其所在作用域的变量,即使该函数在其作用域之外被调用。通过详细解析闭包的定义、创建方法以及实际应用场景,本文旨在帮助读者不仅理解闭包的理论概念,还能在实际开发中灵活运用这一技巧。
|
1月前
|
存储 JavaScript 前端开发
JavaScript 对象的概念
JavaScript 对象的概念
37 4
|
1月前
|
缓存 JavaScript 前端开发
深入了解JavaScript的闭包:概念与应用
【10月更文挑战第8天】深入了解JavaScript的闭包:概念与应用
|
1月前
|
前端开发 JavaScript 程序员
【从前端入门到全栈】Node.js 之核心概念
【从前端入门到全栈】Node.js 之核心概念
|
1月前
|
缓存 JavaScript 前端开发
Node.js模块化的基本概念和分类及使用方法
Node.js模块化的基本概念和分类及使用方法
32 0
|
1月前
|
自然语言处理 JavaScript 前端开发
深入理解JavaScript中的闭包:概念与应用
【10月更文挑战第8天】深入理解JavaScript中的闭包:概念与应用
|
2月前
|
自然语言处理 JavaScript 前端开发
探索JavaScript中的闭包:从基础概念到实际应用
本文深入探讨了JavaScript中闭包的概念,从定义、作用域链和实际应用等方面进行了详细阐述。通过生动的比喻和实例代码,帮助读者理解闭包在函数执行上下文中的重要性,以及如何在实际开发中有效利用闭包解决复杂问题。同时,文章也指出了过度使用闭包可能导致的潜在问题,并给出了相应的优化建议。
|
3月前
|
JavaScript 前端开发
js bom的概念
js bom的概念
35 1