js 4

一、循环

例子:1.输入一个数,判断这个数是否是质数

`var num = + prompt("请输入一个数字")
 if(num===1){
 console.log("1不是质数")
 }else {
   {
     if(num===2){
       console.log("2是质数")
     }else{
       for(var i=2;i<=num;i++){
         if(num % i ===0){
           console.log(num+"不是质数")
         }else {
           console.log(num+"是质数")
         }
         break;
       }
     }
   }
 }`

第二种方法:先假定所有的数都是质数,再进行判断,如果其中有一个数可以被整除,那它就是flase,就不是质数。

(个人心得:如何思考是最重要的,不管运用什么样的方法,最终能够得到正确的结果就好,面对如此多的代码,如何让代码更加简单,是优化的重要成分,可以正常思考,可以运用逆向思维,反正哪种简单边用哪种)

例子:2.输出200之内所有的质数

`for(var i = 1;i<=200;i++){
//判断i是否是质数
//判断i是否为1
if(i!==1){
//先假设i是质数
var isPrime = true;
for(var j =2;j <=i-1;j++){
  if(i%j==0){
    isPrime = false;
    break;
  }
}
if(isPrime){
  console.log(i);
}}
}`

二、嵌套循环

例子:九九乘法表

`for(var i=1;i<=9;i++){
   for(var j=i;j<=9;j++){
     console.log(i + "*" + j + "=" + i*j);
   }
 }`

三、冒泡排序

对数组进行排序。 例子:将2,3,1,5,4按照从小到大的顺序排列

`var arr =[2,3,1,5,4]
 for(var i = 0;i < arr.length-1;i++){
  //把数组的前length-i项中的最大的那一项,移动到最右边
   for(var j = 0;j < arr.length-i-1;j++){
     if(arr[j] > arr[j+1]){
      //新建一个临时变量来保存之前arr[j]的值
       var temp = arr[j];
       arr [j] =arr[j+1];
       arr [j+1] = temp;
     }
   }
 }
 console.log(arr)`

(代码最好能够实现重复使用,减少代码的数量,做到美观,可读性高)

for循环中嵌套相同的变量名会有影响,但是分开的两个循环有两个相同变量名,不会有影响。

换行符:\n

四、函数

封装代码块,同样的内容重复使用便可以用函数封装。增强代码的可读性。

1)、字面量(常亮),只能代表一个值,是唯一的,而变量可以有多个值,会改变:

1.10->代表数字10

2.‘hello‘->代表字符串hello

2)、函数在定义的时候,所定义的参数(小括号里的内容),叫做形参;函数在调用的时候,所传入的参数,叫做实参。

3)、函数的执行顺序:

计算实参的值,把计算所得出来之后的值,作为传入函数的数据;

系统自动去申明形参;

执行函数语句块里面的内容。

4)、函数定义的方式

函数声明:function 函数名(形参){语句块}

函数表达式:var 函数名=function (形参){语句块}(把匿名函数赋值给变量)

js中可以把函数当做参数传入函数

5)、函数声明和函数表达式的区别

函数声明:函数提升,对于使用函数声明方式定义的函数,它的定义时机会被提前到整个代码的开头,千万不要在判断中使用函数声明来定义函数,由于函数提升的存在,判断便不起作用,如果非要在判断中使用函数,请使用函数表达式。

6)、函数的返回值

用return语句来定义函数的返回值。

return语句除了定义函数的返回值,还拥有结束整个函数的作用。

时间: 2024-10-28 10:04:11

js 4的相关文章

【API】高德地图API JS实现获取坐标和回显点标记

1.搜索+选择+获取经纬度和详细地址 2.回显数据并点标记 3.实现 第一步:引入资源文件 <!--引入高德地图JSAPI --><script src="//webapi.amap.com/maps?v=1.3&key=在官网申请一个key"></script><!--引入UI组件库(1.0版本) --><script src="//webapi.amap.com/ui/1.0/main.js">

js跨域

第一次写博客,好紧张,不知道能写成啥样,哈哈哈. 自己的一知片解,有错请多多指教,嘻嘻嘻. 一.何为跨域? 只要协议.域名.端口后任何一个不同,就是跨域. 举个例子: http://www.example.com 协议不同 https://www.example.com http://www.example.com 域名不同 http://www.test.com http://www.example.com 端口不同 http://www.example.com:81 注意:ip相同,域名不同

Vue.js学习笔记:属性绑定 v-bind

v-bind  主要用于属性绑定,Vue官方提供了一个简写方式 :bind,例如: <!-- 完整语法 --> <a v-bind:href="url"></a> <!-- 缩写 --> <a :href="url"></a> 绑定HTML Class 一.对象语法: 我们可以给v-bind:class 一个对象,以动态地切换class.注意:v-bind:class指令可以与普通的class特

node.js的安装及配置

一.安装 直接在浏览器搜索node.js,在官网上下载(一般旧版的更加稳定,比如下载4.4.7版本) 点击DOWNLOADS 往下翻,点击Previous Release Windows下载msi(64位/32位) 根据提示一步步安装,安装之后的文件夹如下: 在cmd命令行下输入node -v,如果出现如下,说明安装成功: 二.关于配置 在安装路径下新建两个文件夹: 创建完两个空文件夹之后,打开cmd命令窗口,输入 npm config set prefix "D:\Program Files

Node.js 使用angularjs取得Nodejs http服务端返回的JSON数组示例

server.js代码: // 内置http模块,提供了http服务器和客户端功能(path模块也是内置模块,而mime是附加模块) var http=require("http"); // 创建服务器,创建HTTP服务器要调用http.createServer()函数,它只有一个参数,是个回调函数,服务器每次收到http请求后都会调用这个回调函数.服务器每收到一条http请求,都会用新的request和response对象触发请求函数. var server=http.createS

Knockout.js简介

Knockout是一款很优秀的JavaScript库,通过应用MVVM模式使JavaScript前端UI简单化.任何时候你的局部UI内容需要自动更新,KO都可以很简单的帮你实现,并且非常易于维护. Knockout的3个核心功能是: ? 属性监控与依赖跟踪 ? 声明式绑定 ? 模板机制 MVVM Model-View-View Model (MVVM)是一种创建用户界面的设计模式. ? Model:用于存储应用程序数据,表示业务领域的对象和数据操作,并且独立于任何界面. 当使用KO的时候,通常是

vue.js 入门

简单一句话来描述:vue.js是一个前端框架. 官方文档:https://cn.vuejs.org/v2/guide/index.html 虽然,我以前也会改一些前端样式,但主要是基于HTML和CSS,HTML主要控制页面的结构,CSS主要来控制样式.涉及到JavaScript就比较小白了. 我花了一个下午照着官方文档做练习,当然是只创建一个xxx_demo.html文件,在<script></script> 标签对之间写 Vue.js语法.这不算错,但在工程化的今天,这么学得猴年

JS高程3:JSON

JSON,JavaScript Object Notation,JS对象表示法,是目前最常见的结构化数据传输形式. JSON并非编程语言,而是一种数据结构,像mp4.avi一样,只是一种数据格式而已.(数据结构可以包含很多数据类型) JSON值的类型 简单值 对象 数组 简单值:字符串.数字.布尔值和null,注意不包括undefined. 注意:JSON中的字符串必须用双引号. 对象:对象就是无序的键值对,而键值中的值也可以是简单值.对象或者数组. 注意:JSON中对象的属性必须用双引号括起来

js装饰器

本文是廖雪峰老师js教程的学习笔记 JavaScript的所有对象都是动态的,即使内置的函数,我们也可以重新指向新的函数. 利用apply(),我们还可以动态改变函数的行为. 现在假定我们想统计一下代码一共调用了多少次parseInt(),可以把所有的调用都找出来,然后手动加上count += 1,不过这样做太傻了.最佳方案是用我们自己的函数替换掉默认的parseInt(): var count = 0; var oldParseInt = parseInt; // 保存原函数 window.p

Vue.js系列之项目搭建(vue2.0 + vue-cli + webpack )

1.安装node node.js环境(npm包管理器) cnpm npm的淘宝镜像 从node.js官网下载并安装node,安装过程很简单,一路"下一步"就可以了(傻瓜式安装).安装完成之后,打开命令行工具,输入 node -v,如果出现相应的版本号,则说明安装成功. npm包管理器,是集成在node中的,所以,直接输入 npm -v就会显示出npm的版本信息. 2.安装cnpm 在命令行中输入 npm install -g cnpm --registry=http://registr