ES5-3 循環、引用值初始、顯示及隱式類型轉換

1. 循環

  1. for循環的三個參數abc,a只執行一次,c在每次循環后執行
    在這里插入圖片描述
    在這里插入圖片描述
    在這里插入圖片描述
    在這里插入圖片描述
    在這里插入圖片描述
    在這里插入圖片描述
    在這里插入圖片描述
// 打印0-100的質數 1不是質數
var list = [2]
for (var i = 3; i <= 100; i = i + 2) {var flag = falsefor (var j = 0; j < list.length; j++) {var cur = list[j]if (i % cur === 0 && cur !== i && cur !== 1) {flag = truebreak}}if (!flag) {list.push(i)}
}
console.log(list)

在這里插入圖片描述

2. 引用值

typeof 操作符返回一個字符串,表示未經計算的操作數的類型。

typeof(123) // 建議該種寫法:typeof是js內置的方法
typeof 123
typeof(數組、正則、對象、Date、基本包裝類) // object
typeof(console.log) // function
typeof(1-1) // number
typeof(1-'1') // number
typeof('1'-'1') // number
typeof(typeof(原始類型/引用類型/函數)) // string
typeof(+) // 報錯

3. 顯式型轉換

  • parseInt(num,radix) 別進制算成十進制
  • xx.toString(radix),十進制算成別進制
// Number目的要轉換成數字
Number(null) // 0
Number(undefined) // NaN
Number('1a') // NaN
Number(true) // 1
// parseInt目的要轉換成整型
parseInt(true) // NaN
parseInt(undefined) // NaN
parseInt(null) // NaN
parseInt('1a') // 1 從第一位開始看,不是數字就是放棄
parseInt('a1') // NaN
parseInt('1a1') // 1
// 十六進制 0123456789abcdef 10 11 12 13 14 15 16 17 18 19 1a
// 二進制 0 1 10 11 100 101 110 111
parseInt(10,radix) // 以radix為基數轉換成十進制 radix-1 轉換結果→16
// radix取值范圍在2-36
parseInt('a',16) // 10
parseInt(10,16) // 16
parseInt(11,16) // 17
parseInt('1a',16) // 26parseFloat('1a') // 1 從第一位開始看,不是數字就是放棄
parseFloat('a1') // NaN
// 數字類型的toFixed()方法是四舍五入的String(null) // 'null'
String(undefined) // 'undefined'
null.toString() // 報錯 Uncaught TypeError: Cannot read property 'toString' of null
undefined.toString() // 報錯 null和undefined沒有toString方法
toString(radix) // 要轉成幾進制
var a = 11 // 先聲明一個數字類型的變量再調用
// 不要直接11.toString Uncaught SyntaxError: Invalid or unexpected token
a.toString(16) // b
// 或者用小括號括起來
(11).toString(16) // b

4.隱式類型轉換

正負號

var a = '123'
console.log(++a) // 124
--------------------
+a // 123
-a // -123
var a = '123'
console.log(a++) // 123
  • Number的隱式類型轉換要和Boolean false的6個值(’’,NaN,undefined,false,0,null)區分開,除了NaN和undefined轉為NaN,其余都是0
  • undefined、null既不大于也不小于、等于0
  • undefined不能和數字比較,null可以和非0數字比較
// undefined、null既不大于也不小于、等于0 ?他們和數字比較時不會做Number轉換
undefined > 0 // false
undefined < 0 // false
undefined == 0 // false
null > 0 // false
null < 0 // false
null == 0 // false
null == undefined // true
null === undefined // falseisNaN('a') // true

在這里插入圖片描述

斐波那契數列:只知道前兩項 1 1 ,其后每項為前兩項之和
var n = 10
// 1 1 2 3 5 01 12 23 8 13 21
var list = [1, 1]
for (var i = 0; i < n - 2; i++) {var newVal = list[i] + list[i + 1]list.push(newVal)
}
console.log(list, list[n - 1])
  • 不使用數組,用移位的思想
  • window.prompt的返回值是字符串
    在這里插入圖片描述

補充

  • parseInt接收2個參數,遍歷時index會作為radix傳入
  • 無論怎么寫,第二個一定是NaN,計算機沒有1進制
const arr = [1, 2, 3, 4]
console.log(arr.map(parseInt)) //  [1, NaN, NaN, NaN]
// parseInt(val,index) 
const arr = [1, 0, 1, 2] 
console.log(arr.map(parseInt)) //  [1, NaN, 1, 2]

在這里插入圖片描述
在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/251217.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/251217.shtml
英文地址,請注明出處:http://en.pswp.cn/news/251217.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

hihocoder 二分

題目 一個簡單的二分&#xff0c;只是想說明一下&#xff0c;如若要查找一個數組中某個數的下標可以直接用lower_bound()這個函數。只是要考慮到要查找的數不在數組中的這種情況。 #include <cstdio> #include <iostream> #include <algorithm> using namesp…

ubuntu開啟ssh服務

更新資源列表&#xff1a;sudo apt-get update -> 輸入管理員密碼 安裝openssh-server: sudo apt-get install openssh-server 查看 ssh服務是否啟動&#xff1a;sudo ps -e |grep ssh 啟動ssh服務&#xff1a; sudo service ssh start 轉載于:https://www.cnblogs.com/ver…

javascript --- 判斷只有1個為真

下面寫一個用于判斷只有一個為真的函數: function onlyOne(a,b,c){return !!((a && !b && !c) ||(!a && b && !c) || (!a && !b && c)); } var a true; var b false;onlyOne(a,b,b) // true onlyOne(a,b,a); // false上述…

13 代碼分割之import靜動態導入

前端首屏優化方案之一 項目構建時會整體打包成一個bundle的JS文件&#xff0c;而有的代碼、模塊是加載時不需要的&#xff0c;需要分割出來單獨形成一個文件塊chunk&#xff08;不會打包在main里&#xff09;&#xff0c;讓模塊懶加載&#xff08;想加載時才加載&#xff09;&a…

2018.01.01(數字三角形,最長上升子序列等)

2017.12.24 簡單的動態規劃 1.數字三角形(算法引入) 題目描述&#xff1a;下圖所示是一個數字三角形&#xff0c;其中三角形中的數值為正整數&#xff0c;現規定從最頂層往下走到最底層&#xff0c;每一步可沿左斜線向下或右斜線向下走。設三角形有n層&#xff0c;編程計算出從…

Mac iOS 允許從任何來源下載應用并打開

一個快捷的小知識點&#xff0c;mark&#xff01; 允許從任何來源下載應用并打開&#xff0c;不用手動去允許&#xff0c;更加簡潔&#xff01; 只需一行命令 sudo spctl --master-disable 1.正常情況下&#xff0c;打開偏好設置&#xff0c;選擇安全性與隱私&#xff0c;界面是…

ES5-4 函數基礎與種類、形實參及映射、變量類型

模塊編程原則&#xff1a;高內聚&#xff0c;低耦合&#xff08;重復部分少&#xff09;&#xff0c;讓一個模塊有強的功能性、高的獨立性 → 單一責任制&#xff0c;用函數進行解耦合。 1. 函數命名規則 不能以數字開頭可以以字母_$開頭包含數字小駝峰命名法 函數聲明一定有…

javascript --- 抽象相等

字符串和數字之間的相等比較 var a 42; var b "42";a b; // false a b; // trueES5規范11.9.3.4-5定義如下: (1)如果Type(x)是數字,Type(y)是字符串,則返回 x ToNumber(y) 的結果 (2)如果Type(x)是字符串,Type(x)是數字,則返回 ToNumber(x) y 的結果// 總結…

Spring加載context的幾種方法

Spring中的context管理 Spring中IOC容器的初始化&#xff1a; ApplicationContext即是保存bean對象的容器&#xff0c;故容器本身的初始化&#xff0c;就是通過一系列的配置&#xff0c;將ApplicationContext進行初始化。 而配置ApplicationContext大方向上分為了3中&#xff1…

centos 6.5 配置網絡

編輯 vi /etc/sysconfig/network-scripts/ifcfg-eth0修改內容 DEVICE"eth0" BOOTPROTO"static" HWADDR"00:50:56:98:06:D0" IPV6INIT"no" MTU"1500" NM_CONTROLLED"no" ONBOOT"yes" TYPE…

ES5-5 參數默認值、遞歸、預編譯、暗示全局變量

1. 參數默認值 默認是undefined形參可以有默認值&#xff0c;形參、實參哪個有值取哪個ES6&#xff0c;默認值屬于ES6的內容&#xff0c;打印出的是符合人性化的結果形參有默認值&#xff0c;形參、實參無法統一、無論實參傳入有值還是undefined&#xff08;代碼表現&#xff…

javascript --- 優先級執行順序

優先級網址 優先級: a && b || c ? c || b ? a : c && b :a// 從優先級網址可以看出 // &&的優先級為:6 // ||的優先級為:5 // ...?...:...的優先級為:4 所以上面的執行順序為(括號的優先級最高為20): ((a && b) || c) ? (c || b) ?…

CodeForces 1009B(思路)

本來打算打打cf找找自信的&#xff0c;結果&#xff0c;死在了一個2000多人都做出來的B上&#xff0c;寫了170多行wr在t4&#xff0c;大佬十幾行代碼就過了&#xff0c;難受啊。 #include <iostream> #include <cstring> #include <algorithm> #include <…

Delphi及C++Builder經典圖書一覽表(持續更新中2018.01.02)

序號書名原版書名作者譯者出版社頁數年代定價備注1CBuilder 5程序設計大全CBuilder 5 Developer’s GuideJarrod Hollingworth康向東、汪浩、黃金才等機械工業出版社13932002.1138.00元2CBuilder應用開發大全Borland C Builder 3 UnleashedCharlie Calvert,et al.徐科、馮焱、呂…

javascript --- 非交互、交互、協作、任務

非交互: var res {};function foo(results) {res.foo results; }function bar(results) {res.bar results; }ajax( "http://some.url.1", foo); ajax( "http://some.url.2", bar);// foo和bar彼此不相關,誰先執行都無所謂..不影響執行結果交互: // 交…

ES5-6 作用域、作用域鏈、預編譯、閉包基礎

1. 作用域 上一級在執行時&#xff0c;內部函數被定義&#xff0c;內部函數便生成作用域和作用域鏈&#xff08;拿上一級的環境&#xff09;&#xff0c;內部函數執行前生成自己的AO&#xff0c;并排在頭部函數執行結束時&#xff0c;AO被銷毀&#xff08;回到被定義時的狀態&…

electron 項目的搭建方式,借助 node 和 npm

1&#xff0c;首先確定安裝了 node 和 npm 2&#xff0c;創建一個文件夾&#xff0c;如 aa 3&#xff0c;CMD 命令進入到 aa&#xff0c;用 npm 命令初始化一個項目 4&#xff0c; npm -init 根據提示完成配置 5&#xff0c;安裝 electron > npm i -D electronlatest, 這一…

zbb20171215 git 版本回退

1. 使用git log命令查看所有的歷史版本&#xff0c;獲取某個歷史版本的id&#xff0c;假設查到歷史版本的id是139dcfaa558e3276b30b6b2e5cbbb9c00bbdca96。 2. git reset --hard 139dcfaa558e3276b30b6b2e5cbbb9c00bbdca96 3. 把修改推到遠程服務器 git push -f -u origin ma…

ES5-7 立即執行函數、閉包深入、逗號運算符

1. 立即執行函數 定義在全局的函數只有關閉瀏覽器或者退出程序才會釋放IIFE: Immediately-Invoked Function Expression解決頁面加載自動執行&#xff0c;執行完成后立即釋放&#xff08;避免了只會執行一次的內容一直存在于全局&#xff09;IIFE用匿名函數或者函數聲明&#…

es6 --- 解構賦值的簡潔性

設想你有一個工具foo,它可以異步產生兩個值(x和y): function getY(x) {return new Promise( function(resolve, reject) {setTimeout( function() {resolve( (3*x) -1 );}, 100);}); }function foo(bar, baz) {var x bar * baz;return getY(x).then( function(y){return [x, …