初识JavaScript
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了初识JavaScript相关的知识,希望对你有一定的参考价值。
写在前面:
经过前段时间对于H5语言的学习,开始慢慢适应现在的生活节奏和代码语言。从一开始的毫无头绪到现在可以大概地写出部分的网站静态页面,用了两个周的时间。作为一个之前从未接触过计算机语言的初学者来说,在感受着代码语言神奇的同时也更期待可以更深入的了解和掌握更多的相关知识,个人能力有限,但尽量做好眼前的每一件事,与大家共勉。
Java Script 是世界上最流行的编程语言。
javascript 是脚本语言
JavaScript 是一种轻量级的编程语言。
JavaScript 是可插入 html 页面的编程代码。
JavaScript 插入 HTML 页面后,可由所有的现代浏览器执行。
JavaScript 很容易学习。
【使用JS的三种方式】
1、在HTML标签中直接使用,直接内嵌JS(但是不提倡使用);
>>>不符合W3C关于内容和行为分离的要求;
eg:
<button onclick="alert(‘你还真的敢点啊~‘)"> 有本事点我啊!</button>
2、在HTML页面中使用<script> </script>标签包裹JS代码;
>>>script标签可以放到页面的各种位置;
eg:
<script type="text/javascript">
JS代码
</script>
3、引入外部的JS文件使用<script> </script>标签;
eg:
<script language="JavaScript" src="JS/01.js"></script>
[注意事项]
①、<script> </script>可以嵌入到页面的任意位置,但是位置的不同将会导致JS代码的执行顺序不同;
比如:<script> </script>放到<body></body>前面,则JS文件会在页面加载之前就执行。
②、引入外部的JS代码 <script> </script> 必须是成对出现的标签,而且标签内部 不能再用任何的JS代码。
【tips】
1、JS中的多行注释。 ( Ctrl+shift+/ )
2、JS中的单行注释。(Ctrl+/ )
PART-1 JS中的变量和输入输出
【JS中的变量】
1、JS中的变量声明写法:(变量的作用域)
var num=10; 使用var声明的变量,属于局部变量,只在当前的区域之内有效;
num=10; 不用var声明的变量,默认为全局变量,在整个JS文件中都有效;
var x=8,y,z=10; 使用一行语句,同时声明多个变量。 上式中,y属于已经声明,但是未赋值状态,结果为undefined;
[声明变量的注意事项]
①、JS中,所有变量的声明均使用var关键字。变量具体是什么数据类型,取决于给变量赋值的类型;
②、JS中,同一个变量可以在多次不同的赋值中,修改变量的数据类型。
var a=10; //在初始声明时,a属于整数型;
a="haha"; //重复赋值时,整数型的a被修改为字符串类型;
③、变量可以使用var声明,也可以不使用;
[区别]使用var声明的变量,属于局部变量,不用var声明的变量,默认为全局变量;
④、只用var声明,但是不赋值,结果为undefined;
例如: var a; // a为undefined;
但是如果不使用var,也不进行赋值,执行结果会报错。
⑤、同一个变量名可以多次使用var声明;
但是后面的var没有什么用了。第二次在使用var声明时,只会被理解为普通的赋值操作;
2、变量名的命名要求:
①、变量名只能由字母/数字/下划线组成。
②、开头不能是数字。
③、变量名区分大小写,大写字母和小写字母为不同变量。
3、变量名的 命名规范:
①、要符合小驼峰法则:首字母小写,之后每个单词的首字母大写;myNameIsWangQiang; √
②、或者使用匈牙利命名法:所有字母小写,单词之间用下划线分开; my_name_is_wang_qiang;√
③、 mynameiswangqiang √ 但是不规范;
4、 JS中的数据类型: (均用var引用,但是赋值类型不同) ("▔□▔)"重点!!!
①、Undefined:已经使用var进行了声明,但是未进行赋值;eg:var=a; 此时a为未赋值的变量,运行显示undefined;
②、Null:表示空的引用;
③、Boolean:布尔类型:只有两个值:true、false,表示真假;
④、Number:数值类型。可以为整数,也可以为小数;
⑤、String:字符串类型;用"或"包裹的内容,称为字符串;
⑥、Object:对象类型;
5、【常用的数值函数】
①、isNaN();判断一个变量或者常量是不是NaN(not a number);
使用isNaN();判断时会尝试使用number()函数进行转换,如果最终结果能够转换为数字,则不是NaN.结果为false;
②、Number():将其他类型的数据尝试转换为数值形式;
[字符串类型]
>>>字符串为纯数值字符串,这会转换成相应的数值;"111">111
>>>字符串为空的字符串,会转为0; "">0
>>>字符串包含其他任何类型的字符时,均不能进行转换;"1a">NaN
[Boolean类型] ture>>1 false>>0
[Null/Undefined类型] Null>0 Undefined>NaN
[Objiect类型] 待讲
③、ParseInt() 将字符串转换成整数类型;!!!
>>>纯数值字符串,能转。"12">12 "12.9">12 小数在转换时直接被抹掉,不进行四舍五入;
>>>空字符串,不能转。"">NaN
>>>包含其他字符的字符串,会截取第一个非数值字符串前的数字部分;"123a456">123; "a123">NaN
>>>ParseInt() 只能转字符串,转其它类型都是NaN;
【Number()与ParseInt() 的区别】("▔□▔)"重点!!!
①、Number()能转所有类型的数据类型,ParseInt() 只能转字符串;
②、两者在转字符串时,结果不完全相同。
④、ParseFloat() :将字符串转换为数值类型;!!!
转换规则与PaseInt相同,如果有小数,则保留小数点。如果没有小数,则依然是整数。
⑤、TypeOf() 检测变量的数据类型:
字符串>string 数值>Number true/false>Boolean
未定义>Undefined 对象/Null>object 函数>function
【JS中常用的输入输出语句】
1、document.write();将括号中的内容打印输出到浏览器的屏幕上;
使用时需要注意除了变量常量外的所有内容必须要放到""中。变量和常量必须放到""外面。
如果同时有变量和常量,必须使用+连接。
eg:document.write("右手中的纸牌 "+right+" <br/> <br/>");
2、alert()使用弹窗输出;
弹窗警告,()中的内容必须 与上述要求相同。
3、prompt 弹窗输入;
接受两部分参数:
①、输入框上部的提示内容,可选。
②、输入框里面的提示信息,可选。
当只写一部分时,表示输入框上部的提示内容。
可以定义变量,接受输入的内容。点击确定按钮,变量将被赋值为输入的内容;
点击取消按钮,变量将被赋值为Null;
输入内容时,默认接收的数据类型都是字符串!!!
eg:
var name= prompt("请输入你的名字","王强") ;
alert("您输入的是"+name);
PART-2 JS中的运算符
1、 算术运算(单目运算符)
+ 加 、-减、*乘、 /除、 %取余数、 ++自增 、--自减
①、+ : 有两种作用:连接字符串、加法运算
当 + 两端全部为数值时,进行加法运算。当 + 两侧中任意一边存在字符串时,就会起到连接字符串的作用,链接之后的结果为字符串。
除了+之外,其余的符号在运算时会尝试将左右变量用Number()将它们转换成数字。
②、/ : 结果会保留小数点 。不限制位数。
③、++ :自增运算符,将变量在原有的基础上面+1;
【a++和++a的异同】
>>相同点: 无论a++还是++a,运算之后的值均会+1;
>>不同点:a++先用a的值去运算,再把a+1;
++a先把a+1,再用结果去运算;
eg:var a=3,b,c;
b=a++ +2;
c=++a +2;
>>>a=5 , b=5 , c=7
④、-- : 自减运算符,将变量在原有的基础上-1;
2、赋值运算
=赋值 += -= *= /= %=
①、+=: a+=b; 相当于a=a+b。 但是推荐使用前者,运算速度快;
eg:
var a=3;
a +=3;
alert(a);
>>6
3、关系运算
==等于、 ===全等、 !=不等、!==不全等、>、<、>=、<=
① 关系运算符运算之后的结果只能是Boolean类型;
② 判断一个数字属否处于某个区间必须用&&连接;
a<10 && a>0 √
10>a>0 ×
③ === 为严格等于,要求不但要类型相同,值也必须相同;类型不同,结果直接为false;相同的话再进行下一步运算;
④ == 为等于 , 类型相同,与===效果一样;类型不同时,会先尝试用Number()将两边函数转换为数字,再进行运算。
但是存在各别的个例: Null===false; ×
Null==Undefined; √
4 条件运算符(多目运算)
a>b?true:false
有两个重要符号: ? :
当?前面部分运算结果为true时,执行:前面的代码;
当?后面部分运算结果为false时,执行:后面的代码;
冒号两边可以为数值,则整个式子可用于赋值。
冒号两端可以为代码块,将直接执行代码。
多目运算符号可以多层嵌套;
5、位运算符、 逻辑运算符
&& 与、||或、 ! 非
&&:两边都成立,结果为true;
||:两边有一边成立,结果为true;
&& 和 ||同时存在时候,&&的优先级高;
6、运算符的优先级:
() 小括号优先级最高
! ++ --
* / %
+ -
> < >= <=
== !=
&& // && 和 ||同时存在时候,&&的优先级高;
||
= += -= *= /= 各种赋值优先级最低;
PART-3 JS中的分支结构
【if-else结构】
1、结构写法:
if(判断条件){
条件为true时执行if的代码
}
else{
条件为false时候执行else的代码
}
2、注意事项:
①、else{}语句块可以根据情况进行省略;
②、if和else后面的{}可以省略,但是省略了之后,它们之后只能跟一条语句,所以不建议省略{};
3、if的()中的判断条件,支持的数据类型: 重点!!!
① Boolean类型:true-真 ;false-假;
② String:空字符串为假,非空字符串为真;
③ Number:0为假,一切非零数字为真;
④ null/Undefined:全为假;
⑤ Object:全为真;
【else-if结构/多层if结构 /阶梯if结构】
1、结构写法:
if(条件一) { }
else if(条件二){ }
else{ }
2、多层if结构中,各个判断条件之间互斥,执行选择符合条件的第一条进行执行,执行之后跳出结构体系,不再继续分支;
【嵌套if结构】
1、结构写法:
if(条件一){ 条件一成立
if(条件二){ 条件一成立,并且条件二也成立; }
else{ 条件一成立,但是条件二不成立; }
}
else{ 条件一不成立 }
2、在嵌套if结构中,如果省略{},则else{}结构属于距离自己最近的if{}结构;
3、嵌套结构可以多层嵌套,但是一般不推荐超过三层;能用多层if就不要用嵌套if;
以上是关于初识JavaScript的主要内容,如果未能解决你的问题,请参考以下文章