作为一个前端工作者,应该了解一些javascript的发展历史,javascript实现及版本等。基本概念包括语法、关键字、变量、数据类型、操作符、语句控制及函数等,它们和我们学习的其它语言C/C++、java、C#等基本上类似,只是存在细微的差别。具体区别及基本学习内容参考JavaScript高级编程相关章节。 
一、基本内容中应该注意的几个地方
1)关于script标签
我们最常用的写法如下:
<script type="text/javascript">
    function(){
        console.log("hello world!");
    }
</script>
 
那么下边这些用法呢?
 
<script type="text/javascript" >
   //<![CDATA[ function(){
        console.log("hello world!");
    }
//]]>
</script>
        在xhtml中,像一些特殊的符号,<> 等等会默认判定为标签,标签后边是不能跟空格的。因此xhtml下要想实现同样的效果,应该转义&lt;,但是这样的代码谁都不想看到。那么可以用CDATA包起来。但是有个特殊的浏览器不支持CDATA怎么办,那就加上//
 
<script type="text/javascript" >
   <!--function(){
        console.log("hello world!");
    }
//-->
</script>
        以上代码是防止一些浏览器不支持javascript(这个顾虑现在基本可以打消了,另外还有个特殊的标签<noscript><p>支持并开启js的浏览器可以看到我</p></noscript>),用html注释的方式包起来,支持js的浏览器会执行。最后一个//防止js执行到-->认为是语法错误
 
<script type="text/javascript" defer="defer">
    function(){
        console.log("hello world!");
    }
</script>
一般用于外部浏览器,defer表示该脚本的执行延迟到整个页面解析完成后再运行,用8个概括就是 立即下载 延迟执行
 
<script type="text/javascript" async>
    function(){
        console.log("hello world!");
    }
</script>
一般用于外部浏览器,顾名思义,不让页面等待脚本的下载,页面的其它部分就可以加载了。
 
        还有建议css代码放到head中,而js代码放到body中的底部。因为html加载是从上往下,如果在body加载之前有很多的脚本需要加载,那么我们用户看到页面空白的时间就会很长。相反,页面展示在用户面前时,用户也不关心还有什么东西没有加载完。这样给用户一个错觉,我们的页面比别人的"快"。那有人就说为了快,怎么不把css文件放到下边?那如果这样做的话,如果页面比较大,样式比较多一开始显示给用户的将会很丑。
 
        在js代码中最好少写 </script>,非要写可以这样 <\/script>,因为当字符中出现</script>,那么html会判断为<script>的结束,后边的代码就不能执行了。
 
在加载js过程中(尤其是js在head中,这样会阻塞UI的加载),不建议动态修改Dom元素,这一点大家可想而知。
 
2)松散型变量和typeof
松散变量的含义就是,变量比较“随意”,可以保存任意的类型。不过我们平时使用时不建议这么用
如:var number=10;
       namber="十";
这样不会报错,但是最好别这样用。
由于变量的这样随意性,因此我们最好通过方法判断该变量当前的类型,typeof很好的解决了这个问题
console.log(typeof "hi jack");//String
console.log(typeof 10);//number
console.log(typeof null);//Object
console.log(typeof message);//undefined
var message="hello jack li";
console.log(typeof message);//hello jack li
3)数据类型中的特殊情况
 
undefied为Undefied类型的值,它只有这一个值。当申明一个值但没有初始化就使用就会报undefined如下:
var message;//其实这里相当于var message=undefined;
console.log(message);//undefined
如果这样呢?
//var error;
console.log(error);//这里会报错,不能执行
更离谱的是如果这样呢?
console.log(typeof error);//undefined 是不是晕了?
总之typeof 可以避免很多无谓的错误。本来上边两种用法都不太推荐。使用变量前 通过typeof判断是个好的习惯,个人理解。
 
Null类型也是只有一个值 null,它是空的对象的指针,因此 typeof null 为Object,同样使用过程中也推荐先判断非空
undefined是派生自null的。因此
console.log(null==undefined);//true
 
Boolean类型也是比较特殊的一个类型
        它只有两个字面量值 true和false,区分大小写,这个在其它语言中也是如此,判断一个变量尤其是前端用户勾选的一些radio或者下拉框中的某个值 和 后台查询出来的值比较,必须 toLowerCase(),统一转化为小写或者大写再比较。
        任何类型的变量都可以转化为Boolean值。利用方法 Boolean(),转换表如下。
类型                             
转换为true的值
转换为false的值
Boolean             
true   
false
String                 
 任何非空字符串
 ""空字符串''也是false 注意没有空格
Number
 任何非0的数字
 0 NaN
Object
任何对象
null
Undefined
n/a
undefined
数值类型和NaN
        整数 浮点数需要注意浮点数的判断 比如if(0.1+0.2==0.3)//永远是false 特定的浮点数计算,最好不要去比较结果,浮点是精度为17
NaN全称是Not a Number。它和任何数的操作结果都是NaN。number/0的结果为NaN。还有一个判断是否为NaN的函数isNaN()
isNaN(100)//false
isNaN(NaN)//true
isNaN("100")//false
isNaN(true)//false
isNaN("message")//true
 
数值转换的一些特殊结果,您掌握多少呢?

Number("Hello jack li");//NaN

 

Number(true);//1

 
Number("000123");//123
一般更常用的是parseInt() parseFloat()
parseInt("123ignore")//123
parseInt("");//NaN
parseInt("0xA");//10
为了消除parseInt("070")//这种转换,我们最好指定第二个参数,明确指出是针对多少进制的转换 parseInt("070",8);//  
parseFloat("123.123.123");//123.123
 
String类型 单引号双引号的含义差不多,但不能交叉嵌套使用
 
var message=null;
var error;
console.log(String(message));//null
console.log(String(error));//undefined
 
Object类型,这个类型比较复杂需要以后单独讲
 
3)操作符
算数操作符,位操作符,关系操作符,相等操作符
 
~按位非
&按位与
|按位或
>>右移 前面保留符号位
<<左移
>>>无符号右移   前面补0
 
相等的特殊情况
null==undefined//true
NaN=="NaN"//false
123==NaN //false
NaN==NaN//false
false==0//true
undefined==0//false
123=="123"//true
 
全等 ===    !==
对比上边的就可以看出===要求更高一些,转换后值相等也不全等。
123==="123"//false
null===undefined//false
 
4)语句控制
需要注意里边的for in 语法就可以了,基本的程序流程控制语句都类似。
 

必须掌握的JavaScript基本知识的更多相关文章

  1. Javascript基础知识总结一

    Javascript基础知识总结一 <!DOCTYPE html> <html> <head lang="en"> <meta chars ...

  2. 学习javascript基础知识系列第二节 - this用法

    通过一段代码学习javascript基础知识系列 第二节 - this用法 this是面向对象语言中的一个重要概念,在JAVA,C#等大型语言中,this固定指向运行时的当前对象.但是在javascr ...

  3. 学习javascript基础知识系列第三节 - ()()用法

    总目录:通过一段代码学习javascript基础知识系列 注意: 为了便于执行和演示,建议使用chrome浏览器,按F12,然后按Esc(或手动选择)打开console,在console进行执行和演示 ...

  4. javascript常用知识点集

    javascript常用知识点集 目录结构 一.jquery源码中常见知识点 二.javascript中原型链常见的知识点 三.常用的方法集知识点 一.jquery源码中常见的知识点 1.string ...

  5. 七个开法者经常忽略或误用的JavaScript基本知识

    七个开法者经常忽略或误用的JavaScript基本知识 翻译自 http://tech.pro/tutorial/1453/7-javascript-basics-many-developers-ar ...

  6. JavaScript 基础知识 - BOM篇

    前言 本篇文章是JavaScript基础知识的BOM篇,如果前面的<JavaScript基础知识-DOM篇>看完了,现在就可以学习BOM了. 注意: 所有的案例都在这里链接: 提取密码密码 ...

  7. JavaScript数组知识

    JavaScript数组知识 <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...

  8. JS控制语句 编程练习 学生数据,分别是姓名、性别、年龄和年级,接下来呢,我们要利用JavaScript的知识挑出其中所有是大一的女生的的名字哦。

    编程练习 在一个大学的编程选修课班里,我们得到了一组参加该班级的学生数据,分别是姓名.性别.年龄和年级,接下来呢,我们要利用JavaScript的知识挑出其中所有是大一的女生的的名字哦. 学生信息如下 ...

  9. AST抽象语法树——最基础的javascript重点知识,99%的人根本不了解

    AST抽象语法树——最基础的javascript重点知识,99%的人根本不了解 javascriptvue-clicommonjswebpackast  阅读约 27 分钟 抽象语法树(AST),是一 ...

  10. javascript常用知识汇总

    javascript这个语言庞大而复杂,我用了三年多了,还是皮毛都不会.从刚开始的jquery,到后来的es6,每天都在学习,每天都在忘记. 1.禁止手机虚拟键盘弹出 在开发适配手机的页面时,出现了这 ...

随机推荐

  1. 最受欢迎telnet

    点击开关在模拟器,它相当于实PC经由控制线连接真实开关 由于我使用telnet远程登录到交换机的话.因为telnet工作在TCP/IP模型的应用层,现在让应用层通信的话,我首先要保证网络层通信,通信, ...

  2. hdu4758 Walk Through Squares 自动机+DP

    题意:给n*m的地图,在地图的点上走,(n+1)*(m+1)个点,两种操作:往下走D和往右走R.现在要从左上角走到右下角,给定两个操作串,问包含这两个串的走法总共有多少种. 做法:用这两个串构建自动机 ...

  3. 彩色图像--色彩空间 YIQ 、YUV 、YCbCr 、YC1C2 和I1I2I3

    学习DIP文章64天 转载请注明文章出处:http://blog.csdn.net/tonyshengtan .出于尊重文章作者的劳动,转载请标明出处.文章代码已托管,欢迎共同开发:https://g ...

  4. 使用Enterprise Architecture绘制10种UML画画

    UML绘制10种课程要求UML画画,选Enterprise Architecture作为一个绘图工具,每一个草图必须是网上找教程,我觉得很麻烦,还有一些数字并没有找到详细的教程.在我自己找一个绘图方法 ...

  5. asp.net学习之扩展GridView

    原文:asp.net学习之扩展GridView 本节讨论如何从现有的控件,进而扩展成强大的,更定制的GridView控件 1.扩展BoundField 默认的BoundField不能显示多文本,文字一 ...

  6. HDU4828 Grids 2014百度之星预赛问题解决

    看看Catalan数的公式:为 Catalan(n) = C(2n, n) / n+1 = C(2n, n) - C(2n, n-1); (公式0) 然后利用全排序表达:Catalan(n) = (2 ...

  7. csdn 博客,你很努力,有人帮你-2015年03一个月17日本

    今天泛化 开始使用简书 正则表达式的博客写了两篇文章 回顾 Core Data 基本使用 总结 Xcode6新特性 简单聊聊 简书,事实上一開始学 MarkDown 语法的时候,已经用了,但是,一直认 ...

  8. wcf系列5天速成——第一天 binding的使用(1)

    原文:wcf系列5天速成--第一天 binding的使用(1) 作为WCF速成系列,只介绍些项目开发中常用到的实战知识. 学习wcf,还是对其中的几个术语要了解一下.wcf中有一个ABC的概念,就是 ...

  9. 从头开始学JavaScript (三)——数据类型

    原文:从头开始学JavaScript (三)--数据类型 一.分类 基本数据类型:undefined.null.string.Boolean.number 复杂数据类型:object object的属 ...

  10. Xcode6为什么干掉pch(Precompile Prefix Header)&amp;怎样加入pch文件

    一直在用xcode6开发,但项目都是在xcode5上创建的,所以一直没注意到,xcode6居然干掉pch文件了. 为什么xcode6没有自己主动创建pch文件呢? 简单地看:我们在写项目的时候,大部分 ...