JavaScript初步
隐式转换
其他类型转换成布尔类型:
undefined --> false
null --> false
0或者0.0或者NaN --> false
字符串长度为0 --> false
其他对象 --> true其他类型转换成数值类型:
undefined --> NaN
null --> 0
true --> 1
false --> 0
内容为数字 --> 数字
内容为非数字 --> NaN
其他对象 --> NaN其他类型转换成字符串类型
undefined --> 'undefined'
null --> 'NaN'
true --> 'true'
false --> 'false'
数值型 --> NaN 或者0 或者数值对应的字符串
其他对象 --> 存在就住转化为toString()方法的值,否则就是undefined
显示转换
其他类型转换成布尔类型
使用Boolean()函数其他类型转换成字符串类型
使用String()函数其他类型转换成数值型
使用Number()强制转换成数值,是一种严格的转换,只要里面有一个字符无法转换,就是NaN
使用parseInt(string,radix) 返回转换之后的整型值,如果八进制,就转换成八进制,
第二个参数,指定转换的进制,2,8,10,16
使用parseFloat(string) 返回转换之后的浮点型的值
运算符
算术运算符:+ - * / % ++ -- 其中++ --分位前缀和后缀
字符运算符:+ 使用+连接多个字符串
赋值运算符:= += -= *= /= %= .=
比较运算符:> >= < <= == != === !==
逻辑运算符:&& || ! 运算结果为布尔类型,存在短路现象
三元运算符:exp1?exp2:exp3 如果exp1成立,就执行exp2,否则就是exp3
其它运算符:
逗号运算符:
逗号用来将多个表达式连接成一个表达式,新表达式的值为最后一个表达式的值,多用在变量声明处
如: var a=1,b=2,c=3; 声明三个变量
var a=(n=1,m=2,z=3) 此时,a的值为最后一个表达式的值,为3void运算符:
void运算符用来指明一个表达式无返回结果,可以用在函数,无返回值,或者无参数
a = void() 表示undefinedtypeof运算符:
typeof运算符用来返回一个操作数的数据类型
运算符优先级
按照优先级降低的顺序如下:
.[]() 字段访问,数组下标,函数调用以及表达式分组
++ -- - ~ ! delete new typeof void 一元运算符,返回数据类型,对象创建,未定一只
* / % 乘法,除法,取模
+ - + 加法,减法,字符串连接
<< >> >>> 移位
< <= > >= instanceof 小于,小于等于,大于,大于等于,instanceof
== != === !== 等于,不等于,严格相等,非严格相等
& 按位与
^ 按位抑或
| 按位或
&& 逻辑与
|| 逻辑或
?: 条件
= oP= 赋值,运算赋值
, 多重求职
可以通过括号()来改变优先级。
流程控制
- 条件语句:
if(exp) 执行一句代码
if(exp){执行代码段}
if(exp){exp为True时执行}else{exp为false的时候执行;}
if(exp1){...}else if(exp2){...}
switch...case
if嵌套
// 严格类型比较
switch(exp){
case 值1:
执行的代码段;
break;
case 值2:
执行的代码段;
break;
default: /可以放在任何地方,不一定是末尾
执行的代码段;
break;
}
- 循环语句:
- for(判断条件){循环体}
// 使用for循环打印九九乘法表
<script type="text/javascript">
document.write('<hr color="red">');
document.write('<table border="1" cellpadding="0" cellspacing="0" bgcolor="#ABCDEF" width="80%">');
for(var i=1;i<=9;++i){
document.write('<tr>');
for(var j=1;j<=i;j++){
document.write('<td>'+i+'x'+j+'='+(i*j)+'</td>');
}
document.write('</tr>');
}
document.write('</table>');
</script>
- while(判断条件){循环体}
var i=1;
while(i<=10){
document.write(i);
documetn.write('<hr/>');
i++;
}
- do{循环体}while(判断语句)
var i=1;
do{
document.write('hello world');
}while(false);
JavaScript初步的更多相关文章
- python成长之路【第十五篇】:JavaScript初步认识
JavaScript是一门编程语言,浏览器内置了JavaScript语言的解释器,所以在浏览器上按照JavaScript语言的规则编写相应代码之,浏览器可以解释并做出相应的处理. 一.如何编写 1.J ...
- Javascript——初步
1.基本概念 Javascript是一门脚本语言,它是一门解释性的语言.网页和用户之间实时.动态的进行交互. 2.特点 简单性:没有严格的数据类型.语句简单而紧凑. 安全性:仅仅能通过浏览器实现浏览和 ...
- HTML 5 JavaScript初步 编译运行.doc
编译运行 解释运行 JavaScript:只有一种变量类型,var.数据类型:整型,小数,字符串,布尔型 1.如何把数值型字符串变成数字型: parseInt("字符串")——把字 ...
- javascript初步了解
0.1 <script> 和 </script> 会告诉 JavaScript 在何处开始和结束. <script> 和 </script> 之间的 ...
- JavaScript 初步认识
首先呢 要成为WEB全栈工程师呢 JavaScript 是必须要会的 高级技术看自身兴趣爱好,但是基础必须掌握 因为有良好的基础学习jQuery会比较轻松. js是一门轻量的脚本语言 我学它主要目的是 ...
- JavaScript初步学习----基本使用,简单事件,修改样式,数据类型
JavaScript基本使用 JavaScript原名叫livescript,是一门动态类型,弱类型基于原型的脚本语言 用于页面特效,前后交替,后台开发(node) JavaScript写在s ...
- JavaScript基于对象编程
js面向对象特征介绍 javascript是一种面向(基于)对象的动态脚本语言,是一种基于对象(Object)和事件驱动(EventDirven)并具有安全性能的脚本语言.它具有面向对象语言所特有的各 ...
- Python基础+Pythonweb+Python扩展+Python选修四大专题 超强麦子学院Python35G视频教程
[保持在百度网盘中的, 可以在观看,嘿嘿 内容有点多,要想下载, 回复后就可以查看下载地址,资源收集不易,请好好珍惜] 下载地址:http://www.fu83.cc/ 感觉文章好,可以小手一抖 -- ...
- div模拟selection标签 下拉列表
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
随机推荐
- A Beginner’s Guide to Eigenvectors, PCA, Covariance and Entropy
A Beginner’s Guide to Eigenvectors, PCA, Covariance and Entropy Content: Linear Transformations Prin ...
- .net core 中 Identity Server 4 Topic 之 Startup
约定 简称 Id4. Id4在.net core 中的使用符合.net core 的约定架构,即Services来注册服务,middleware方式集成. 1. 配置服务 通过DI注入: public ...
- 强大的jQuery网格插件 ParamQuery
ParamQuery是一种轻量级的jQuery网格插件,基于用于用户界面控制.具有一致API的优秀设计模式jQueryUI Widget factory创建,能够在网页上展示各种类似于Excel和Go ...
- 【CODEVS】2800 送外卖
[算法]最短路(floyd)+状态压缩型动态规划 [题解] 经典的TSP问题(货郎担问题):求最小权哈密顿回路(遍历全图点一次且仅一次).本题稍作改动,先说原TSP问题解法:状压DP. 状态用二进制表 ...
- 【BZOJ】3991: [SDOI2015]寻宝游戏 虚树+DFS序+set
[题意]给定n个点的带边权树,对于树上存在的若干特殊点,要求任选一个点开始将所有特殊点走遍后返回.现在初始没有特殊点,m次操作每次增加或减少一个特殊点,求每次操作后的总代价.n,m<=10^5. ...
- Vue笔记之props验证
使用props 在Vue中父组件向子组件中传送数据是通过props实现的,一个简单的使用props的例子: <!DOCTYPE html> <html> <head> ...
- SpringMVC可以配置多个拦截后缀*.action和.do等
首先介绍一下.do和.action的区别: struts早期的1版本,以.do为后缀. 同时spring的MVC也是以.do为后缀. 几年前struts收购鼎鼎大名的webwork2和开发团队后,将w ...
- 阿里分布式开源框架DUBBO 入门+ 进阶+ 项目实战视频教程
史诗级Java/JavaWeb学习资源免费分享 欢迎关注我的微信公众号:"Java面试通关手册"(坚持原创,分享各种Java学习资源,面试题,优质文章,以及企业级Java实战项目回 ...
- 用C#实现对MSSqlServer数据库的增删改查---Server层(WaterLevelRecordServer.cs、DeviceRecordServer.cs)
抛开现实的残酷与无奈,对技术孜孜不倦的追求,从专注到执着,从疯狂到忘我,始终坚信代码可以改变世界,更能改变自己的人生. WaterLevelRecordServer.cs using System; ...
- vmware linux虚拟机连接ip设置
首先: 点击VMware 编辑->虚拟网络编辑器: 然后选中VMnet8的查看NAT设置: 上图第二步(记下红框中网关地址和子网掩码): 第三步(用于设置虚拟机地址范围): 接下来就是设置虚拟机 ...