一、字符串新特性--双丿(撇)号声明字符串
、多行字符串
var myName = `fang
my hao li
jsk c sdf` //这样不会报错。
、字符串模板
console.log(`qsdaf ${myName}`)
console.log(`qsdaf ${myName()}`)//函数和变量可以直接写这里面${}
console.log(`<div>
<span>${myName}</span>
</div>`)//这样就可以很快的写出来,而不用加号连接;
、自动拆分符串
function test(a,b,c) {
console.log(a);
console.log(b);
console.log(c);
}
var myname = 'ni hao';
var getAge = function(){
return 18
}//下面的调用,a为一个数组['hello my name is',',im','']; b为'ni hao';c为18;也就是说这样会以变量为分隔
test`hello my name is ${myname},im ${getAge()}`;
二、 参数新特性
1、 参数类型--在参数名称后面使用冒号来指定参数的类型
、any 可以任何类型
var myname: any = 18;
、string 字符串类型
var myname: string = "zhang san"
、number 数字类型
var my: number = 20
、boolean 布尔类型
var name: boolean =true
function test (name:string):string {
return ""
}//意思为参数只能为字符串,函数返回值也只能是字符串;
、自定义类型
class person {
name:string;
age: number;
}
var zhangsan :Person = new Person()
zhangsan.name = "zhailiang";
zhangsan.age = 18
2、 参数默认值--在参数声明后面用等号来指定参数的默认值
var my: string = "fang";
function test(a:string,b:string,c:string="wo"){
console.log(a)
console.log(b)
console.log(c)
}
test{'sfa','sss','asd'}//没有给默认值时必须给3个参数不然会报错;有默认值的参数可以不写(但必须写在最后面)
3、可选参数--在方法的参数声明后面用问号标明此参数为可选参数
function test(a:string,b?:string,c:string="wo"){
console.log(a);
console.log(b);//为b.length时会报错
console.log(c);
}
test{'sfa'} //这样不会报错,b为undefined;还有一个注意的也像默认参数一样,可选参数必定要写在必写参数的后面
三、函数新特性
1、Rest and Spread操作符(...)--用来声明任意量的方法参数
function func1(...args) {
args.forEach(function(arg){
console.log(arg);
})
}
func1(1,2,3);func1(1,3,4,5,6)//正向用
function func2(a,b,c) {
console.log(a);
console.log(b);
console.log(c);
}
var args = [1,2],args1 = [5,6,7];
func1(...args);func1(...args1)//反向用
2、generater函数--控制函数的执行过程、手工暂停和恢复代码执行
function* doSomething(){
console.log("start");
yield;
console.log("finish")
}
var fun1 =doSomething();
func1.next();//会在yield的地方停止
func1.next();
3、destructuring析构表达式--通过表达式将对象或数组拆解成任意数量的变量
function getStock(){
return {
code:"IBM",
price: {
price1:100,
price2:200
}
}
}
var {code:codex,price:{price2}} = getStock();
console.log(codex);
console.log(price2)//从对象中拆解
var array = [1,2,3,4];
var[number1,number2] = array;
console.log(number1)//1
console.log(number2)//2
var[,,,number1,number2] = array;
console.log(number1)//3
console.log(number2)//4
var[number1,number2,...others] = array;
console.log(number1)//1
console.log(number2)//2
console.log(others)//[3,4]
四、表达式和循环
1、箭头表达式--用来声明匿名函数,消除传统匿名函数的this指针问题
var sun = (arg1,arg2) =>arg1+arg2//只有一行不用写大括号,也不用写return关键字
var sun =arg3 =>console.log(arg3)//只有一个参数时不用写小括号
var myArray = [1,2,3,4,5,6];
console.log(myArray.filter(value =>value%2 == 0)) function gerStock(name:string){
this.name = name;
setInterval(()=> {
console.log("name is:" + this.name);
},1000)
}
var stock = new getStock("IBM")//可以看到打出来为“name is: IBM”,消除了传统匿名函数this指针问题,要是用ES5写就拿不到IBM
2、forEach() ,for in 和 for of
var myArray = [1,2,3,4];
myArray.desc = 'four number';
myArray.forEach(value=>console.log(value))//会忽略掉它的属性,并且不可以被打断
for (var n in myArray){
console.log(n)//打出的键值对的键和属性 0,1,2,3,desc
console.log(myArray[n])//打出的每一个值
}
for (var n of myArray) {
if(n>2) break;
console.log(n)
}//和forEach差不多只是可以被打断用break ;集合,数组都可以用,也可以用在字符串上,这时会把字符串的每一个字符都打印出来

typeJavaScript笔记----字符串,参数,函数,表达式,循环的更多相关文章

  1. JavaScript高级程序设计(读书笔记)之函数表达式

    定义函数的方式有两种:一种是函数声明,另一种就是函数表达式. 函数声明的一个重要特征就是函数声明提升(function declaration hoisting),意思是在执行代码前会先读取函数声明. ...

  2. JavaScript 高级程序设计(第3版)笔记——chapter7:函数表达式

    一.函数表达式的语法形式 匿名函数 var functionName = function(arg0, arg1, arg2) { //函数体 } 二.函数表达式没有函数提升 var a = 1; i ...

  3. javascript笔记05:函数表达式和函数语句的区别

    1.首先是函数语句: myfunc(); function myfunc() { //执行一些语句 } 当函数语句被定义的时候,在一个脚本代码被优先考虑,因此,无论该函数是定义之前或者定义之后都可以被 ...

  4. C学习笔记-字符串处理函数

    字符串函数是最问常用的库函数之一,本文整理了常用的字符串函数,其来源为互联网 函数名: stpcpy 功 能: 拷贝一个字符串到另一个 用 法: char *stpcpy(char *destin, ...

  5. Java学习笔记——字符串常用函数

    class JavaTest4_String { public static void main(String[] args) { String str1 = "IOS,ANDROID,BB ...

  6. js高级程序设计(七)函数表达式

    定义函数的方式有两种:一种是函数声明,另一种就是函数表达式.函数声明的语法是这样的. function functionName(arg0, arg1, arg2) { //函数体 } Firefox ...

  7. 字符串join函数跟+号测试

    字符串join函数for循环+区别: 原因是这样的,字符串是不可变对象,当用操作符+连接字符串的时候,每执行一次+都会申请一块新的内存,然后复制上一个+操作的结果和本次操作的右操作符到这块内存空间,因 ...

  8. Scala学习笔记(二)表达式和函数

    笔记的整理主要针对Scala对比Java的新特性:   1.if表达式 if表达式是有结果返回的. val a= if (5>2) "你好" else 1 a的值为if表达式 ...

  9. <深入理解JavaScript>学习笔记(4)_立即调用的函数表达式

    前言 大家学JavaScript的时候,经常遇到自执行匿名函数的代码,今天我们主要就来想想说一下自执行.(小菜理解:的确看到好多,之前都不知道这是自执行匿名函数) 在详细了解这个之前,我们来谈了解一下 ...

随机推荐

  1. 解决ZF2_PATH environment

    本方法基于:ZendFramework 2.1.4版本在WIN7下构建,其他版本的安装方式相差不大. 操作之前您需要搭建好PHP运行环境,保证PHP版本不低于PHP 5.3.3,并且去http://f ...

  2. "手机信号放大器" 让手机信号增强的办法

    我的住处信号及其的差,电话基本打不进来,放大器的话便宜的也得一百多,于是自己尝试各种办法让自己的手机有信号,于是奇迹般的成功了: 将手机放于铁缸内,并45度角斜放,刚好淹没手机为佳.于是信号奇迹般的3 ...

  3. AngularJS学习笔记filter

    filter是对数据进行过滤操作,比如按某个字段搜索.格式化数据等等,是一个非常有用的接口.下面就简单介绍下它的用法. AngularJS自带的filter接口,|是filter的分隔符,参数用:分隔 ...

  4. 【转载】如何让Chrome浏览器允许本地环境支持Ajax

    转载自:http://www.bewxx.com/news/news_89.html 对于网站前端人员来说,我们在本地开发程序的时候如果用到Ajax的话,通常会使用Firefox来测试,因为Firef ...

  5. css,js工具篇

    4. web前端开发分享-css,js工具篇   web前端开发乃及其它的相关开发,推荐sublime text, webstorm(jetbrains公司系列产品)这两个的原因在于,有个技术叫emm ...

  6. 几个 jQuery 小提示和技巧

    几个 jQuery 小提示和技巧 今天,我们将分享一些很有用的技巧和窍门给 jQuery 开发人员.jQuery 是最好的 JavaScript 库之一,用于简化动画,事件处理,支持 Ajax 和 H ...

  7. Word文档合并

    Word文档合并的一种实现   今天遇到一个问题,就是需要把多个Word文档的内容追加到一个目标Word文档的后面,如果我有目标文档a.doc以及其他很多个文档b.doc,c.doc…等等数量很多.这 ...

  8. Lambda应用模式

    Lambda应用模式 前言 在使用 Lambda 表达式时,我们常会碰到一些典型的应用场景,而从常用场景中抽取出来的应用方式可以描述为应用模式.这些模式可能不全是新的模式,有的参考自 JavaScri ...

  9. MACOSX 命令行设置无效网关ip

    sudo需要管理员权限 sudo networksetup -setmanual Ethernet 192.168.10.100 255.255.255.0 0.0.0.0 网络设置界面会报错: Ba ...

  10. [置顶] iOS学习笔记47——图片异步加载之EGOImageLoading

    上次在<iOS学习笔记46——图片异步加载之SDWebImage>中介绍过一个开源的图片异步加载库,今天来介绍另外一个功能类似的EGOImageLoading,看名字知道,之前的一篇学习笔 ...