JavaScript基础-03
1. 条件判断语句
若条件成立才会执行,条件不成立则语句不执行;
if语句
语法一:
if(条件表达式)
{语句} :true就执行,false不执行;
语法二:
if(条件表达式)
{语句}
else {语句}
语法三:
if(条件表达式)
{语句}
else if (条件表达式) {语句}
else if (条件表达式) {语句}
else{语句}
2. 条件分支语句:switch语句
语法:
switch(条件表达式1){
case 表达式2:
语句......
break;
case 表达式:
语句......
break;
default:
语句......
break;}
执行流程:在执行时会一次将case后的表达式2的值和switch后的条件表达式1的值进行全等比较,如果比较结果为true,则执行语句;若比较结果为false,则接着下去执行。若所有比较结果是false,则只执行default后的语句。
3. 循环语句
通过循环语句可以反复的执行一段代码多次
while循环:
语法:while(条件表示式){
语句.....
break;}
执行过程:先对条件表达式进行求值判断,如果值为true,则执行循环体,执行完毕以后,继续对表达式进行判断,如果值为true,则执行循环体,以此类推。若值为false,终止循环。
向这种将条件表达式写死为true的循环,叫做死循环,慎用
var n=1;
while(true){
alert(n++);
if ( n==10){
break;}}
创建一个循环,需要三个步骤:
- 创建初始化一个变量:var a=0;
- 在循环中设置一个条件表达式:while(i<10)
- 定义一个更新表达式,每次更新初始化变量:i++
var n=1;
while(n<11){
document.write(n++ +'<br/>');}
do...while循环:
语法: do{ 语句.... }
While{ 条件表达式 }
var n=1;
do{document.write(n++ +'<br/>');}
while(n<11);
执行流程:do...while语句在执行时,会先执行循环体,循环体执行完毕之后,在对while后的条件表达式进行判断。
4.for循环
在for循环中,提供了专门位置用来放置三个表达式:
- 初始化表达式
- 条件表达式
- 更新表达式
语法:for ( 初始化表达式;条件表达式;更新表达式 ){ 语句 }
执行流程:执行初始化表达式,初始化变量;(只执行一次)
执行条件表达式,判断是否执行循环;若为true,则执行语句,若为false,终止循环。
执行更新表达式,更新表达式执行完毕继续重复2。
注意:for循环中的三个部分都可以省略,也可以写在外部
若在for循环中不写任何的表达式,只写两个;此时循环是一个死循环,慎用
5.嵌套循环
for(var i=0;i<5;i++){
for(var j=0;j<5;j++){
document.write('*');}
document.write('<br/>');}
形成如下图案:
* ***
** **
*** *
图案一:for(var i=0;i<5;i++){
for(var j=0;j<i+1;j++){
document.write('*');}
document.write('<br/>');}
图案二:for(var i=0;i<5;i++){
for(var j=0;j<5-i;j++){
document.write('*');}
document.write('<br/>');}
9x9乘法表:
for(var i=0;i<10;i++){
for(var j=0;j<i+1;j++){
num=i*j;
document.write(i+'*'+j+'='+num+' '+' '+' ');
}document.write('<br/>');
}
6. break , continue
break:关键字可以用于退出switch或循环语句,会立即终止离他最近的循环语句
for(var i=3;i<8;i++){
console.log(i);
break; //不会执行下去
}
注意:不能在if语句中使用break和continue
label:使用break语句时,可以在break后跟着一个label,这样break就会结束指定的循环,而不是最近。
outer:
for(var i=0;i<8;i++){
for(var j=0;j<8;j++)
{console.log('内部'+j);
break outer;}
console.log('外部'+i);}
Continue:关键字可以跳过当次循环
for(var i=0;i<7;i++){
if(i==2){continue;}
console.log(i);}
7. 测试程序性能
在程序执行前,开启计时器,console.time( ‘计时器的名字’)可以用来开启一个计时器。
停止计时器:console.timeEnd( ‘计时器的名字’)
8. 通过Math.sqrt( ):对一个数进行开方
求质数的最完美方法:
console.time('test');
for(var i=2;i<=10000;i++){
var flag=true;
for(var j=2;j<Math.sqrt(i);j++){
if(i%j==0){
flag=false;
break;}
}
if(flag){
console.log(i);}
}
console.timeEnd('test');
JavaScript基础-03的更多相关文章
- javascript基础03
javascript基础03 1. 算术运算符 后增量/后减量运算符 ++ ,-- 比较运算符 ( >, <, >=, <=, ==, !=,===,!== ) 逻辑运算符( ...
- javaScript基础-03 javascript语句
一. 声明语句 var和function都是声明语句.声明或定义变量或函数. var 声明一个或者多个变量.语法如下: var a ; var b = 1; var c, d; var e = 3; ...
- JavaScript基础03——函数的作用域及变量提升
1.作用域 作用域,变量在函数内部作用的范围/区域.有函数的地方就有作用域. 2.局部作用域和全局作用域 function fn(){ var a = 1; } console.log(a); / ...
- JavaScript基础第03天笔记
JavaScript基础第03天笔记 1 - 循环 1.1 for循环 语法结构 for(初始化变量; 条件表达式; 操作表达式 ){ //循环体 } 名称 作用 初始化变量 通常被用于初始化一个计数 ...
- 前端之JavaScript基础
前端之JavaScript基础 本节内容 JS概述 JS基础语法 JS循环控制 ECMA对象 BOM对象 DOM对象 1. JS概述 1.1. javascript历史 1992年Nombas开发出C ...
- 第三篇:web之前端之JavaScript基础
前端之JavaScript基础 前端之JavaScript基础 本节内容 JS概述 JS基础语法 JS循环控制 ECMA对象 BOM对象 DOM对象 1. JS概述 1.1. javascript ...
- JavaScript 基础学习1-day14
JavaScript 基础学习1 知识预览JavaScript概述二 JavaScript的基础三 JavaScript的对象BOM对象DOM对象实例练习js扩展 JavaScript概述 JavaS ...
- JavaScript基础视频教程总结(071-080章)
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...
- JavaScript基础入门06
目录 JavaScript 基础入门06 Math 对象 Math对象的静态属性 Math对象的静态方法 指定范围的随机数 返回随机字符 三角函数 Date对象 基础知识 日期对象具体API 构造函数 ...
随机推荐
- Azure Traffic Manager(二) 基于权重与基于优先级的路由策略为我们的Web项目提供负载均衡
一,引言 上一片文章我们使用 Azure Traffic Manager 分发用户请求,同时演示了两种路由策略,“Performance”,“Geographic”的两种方式,今天我们继续讲解 Tra ...
- [spring] -- bean作用域跟生命周期篇
作用域 singleton : 唯一 bean 实例,Spring 中的 bean 默认都是单例的. prototype : 每次请求都会创建一个新的 bean 实例. request : 每一次HT ...
- [jvm] -- 内存模型篇
内存模型 JDK1.6 JDK1.8 线程私有的: 程序计数器 虚拟机栈 本地方法栈 线程共享的: 堆 方法区 直接内存 (非运行时数据区的一部分) 程序计数器 线程私有 两个作用 字节码解释器通 ...
- WebView in ScrollView:View not displayed because it is too large to fit into a software layer
报错信息 W/View: WebView not displayed because it is too large to fit into a software layer (or drawing ...
- 为什么我推荐Nginx作为后端服务器代理
1. 前言 我们真实的服务器不应该直接暴露到公网上去,否则更加容易泄露服务器的信息,也更加容易受到攻击.一个比较"平民化"的方案是使用Nginx反向代理它.今天就来聊一聊使用Ngi ...
- Winform开发中的困境及解决方案
在我们开发各种应用的时候,都会碰到很多不同的问题,这些问题涉及架构.模块组合.界面处理.共同部分抽象等方面,我们这里以Winform开发为例,从系统模块化.界面组件选择.业务模块场景划分.界面基类和辅 ...
- 一个调用其他activity的完整例子,使用了 onActivityResult和startActivityForResult
https://blog.csdn.net/qq_32521313/article/details/52451364 Android startActivityForResult基本用法2016年09 ...
- python基础--闭包、装饰器
装饰器的详细使用 (1)小知识点补充 在这里我们先学一个简单的知识点. li = ['alex', '银角', '女神', 'egon', '太白'] for i in enumerate(li): ...
- Django学习路24_乘法和除法
urls 中 url(r'getnum',views.getnum) views.py 中添加对应的函数 def getnum(request): num = 5 context_num = { 'n ...
- 线程_进程间通信Queue合集
# Queue的工作原理 from multiprocessing import Queue q = Queue(3)#初始化一个Queue对象,最多可接收3条put消息 q.put("In ...