2020-07-10

[知识分享]React Native 常用语法总结

  1. 自定义组件导出
    自定义组件在a.js文件中export xx。接受方需用import xx from a,如果在a.js中是export default xx。那么在接受方就不需要也用xx接收,随便aa,bb,cc接收都行,import aa/bb/cc/xx from a.
    注意:在自定义的a.js文件中可多次export xx。但是只能有唯一的export default xx。来声明导出。export default的时候变量名不能用{}包裹,接收也不用。

  2. rest参数-扩展运算符(神奇三点)
    例子:
    let foo = (x,y,…hd)=> {
    console.log(hd);
    return x+y
    }
    console.log(foo(3,4,5,6,7)) //…hd 表示声明一个rest参数,用来接收多余的实参(形参情况下)
    打印结果:Array[5,6,7]. 是将多余的参数5,6,7拼接数组打印出来
    例子:
    Function foo(x,y){
    return x+y;
    }
    在非形参情况下,三个点表示将数组拆分成独立的值。
    let arr = [3,4];
    console.log(foo(…arr)) 等同于 console.log(foo(3,4))
    let arr=[1,2,3];
    let hd=[4,5,6,…arr];
    相当于let hd = [4,5,6,1,2,3]

  3. 数组遍历的方法
    forEach:
    ary:[1,2,3,5]
    this.ary.forEach(x=>{
    console.log(x*x)
    })

    this.ary.map(x=>{
    console.log(x*x)
    })
    Map和foreach用法几乎一样,但是如果对数组本身进行操作的话,要用foreach,可以对数组自身操作。map对数组的元素操作完成后是返回一个新的数组。要用新的数组来接收,原数组不变。

  4. 数组的解构赋值
    let [aa,bb,cc]=['111','222','333']
    console.log(aa+'A'+bb+'B'+cc) 结果:111A222B333
    解构赋值是“模式匹配”,说白了,只要是左右两边的解构一样,就能一一对应。
    例如:一个比较简洁的用法,交换两个变量的值
    let x = 1;
    let y = 2;
    [x,y] = [y,x]
    console.log(x)
    console.log(y)
    其中x,y是同一个变量。
    注意:
    let [a,b]=[1]
    console.log(a) 1
    console.log(b). Undefined
    解构失败的话就是undefined

  5. 对象的解构赋值
    let {ee,ff} = {ee:'12121',ff:'33333'}
    console.log(ee+ff) //1212133333
    let {ff,ee} = {ee:'12121',ff:'33333’}也一样。

  6. 字符串解构赋值 函数参数解构赋值
    let [a,b,c] = ‘后盾人’;
    console.log(a) //后
    console.log(c)//人
    let {length:len} = ‘后盾人’;
    console.log(len); //3
    tt1([x,y]){
    return x*y
    }
    console.log(this.tt1([3,5])). //15
    在传入参数那一刻,参数变量被解构成q和z。对于代码内部来说,他们感受到的参数就是x和y
    [[1,2],[3,4]].map(([q,z]) => q+z) //[3,7]

  7. set数据结构 set本身是一个构造函数,用来生成set数据结构。(类似于数组,但是成员的值都是唯一的,没有重复的值)
    //创建set数据解构
    let sett = new Set();
    //向set数据结构追加数据
    sett.add(1);
    sett.add(2);
    sett.add(1);
    console.log(sett) //set{1,2} 自动过滤重复元素
    let s = new Set([1,2,3,4,5,6,7,2,3,1]);
    console.log(s);//Set(7) {1, 2, 3, 4, 5,6,7}
    //可以通过size属性获得set数据结构的长度
    console.log(sett.size)
    //数组去重
    let arr = [1,2,3,4,5,6,7,2,3,1,2,3]
    let db = [...new Set(arr)];
    console.log(db)
    //set数据结构方法
    let ss = new Set([1,2,3,4,5,5,5,5])
    console.log(ss)
    //追加数据
    ss.add(7)
    console.log(ss)
    //删除数据
    ss.delete(3);
    console.log(ss)
    //判断数据中是否有某值
    let rs = ss.has(2);
    console.log(rs) //true
    //清除所有成员
    ss.clear()
    console.log(ss)
    let sa = new Set([1,2,3,4,5,6,6])
    //set数据转数组(如果有重复元素去除)
    let ew = Array.from(sa); // 《==》 let ew = [...new Set(sa)];
    console.log(ew)
    //set结构的实例有四个遍历方法
    keys():返回键名的遍历器
    values():返回键值的遍历器
    entries():返回健值对的遍历器
    forEach():使用回调函数遍历每个成员
    console.log(sa.keys());//SetIterator {1, 2, 3, 4, 5, 6}
    console.log(sa.values());//SetIterator {1, 2, 3, 4, 5, 6}//这里没有健名所以和健值一样
    //用x去遍历s.keys()产生的值
    for(x of sa.values()){
    console.log(x) // 1,2,3,4,5,6
    }
    for(x of sa.entries()){
    //sa.entries()将set数据的值组成健值对,形成一个集合(因为这里没有键名,所有键名和健值一样)
    console.log(x) // [1,1] [2,2] [3,3] [4,4] [5,5] [6,6]
    }
    sa.forEach(x => {
    console.log(x);
    })

  8. map数据结构. 里面的‘对象’(类似于对象但不是),键名可以是任意类型的(传统json的健值对只能是字符串)
    let m = new Map()
    m.set('name','后盾人')
    let ewq = m.get('name')
    console.log(ewq)//后盾人
    console.log(m)//Map(1) {"name" => "后盾人"}
    m.set(123,'abc')
    console.log(m.get(123))//abc
    let obj = {a:1}
    m.set(obj,111)
    console.log(m.get(obj))
    //作为构造函数,Map也可以接收一个数组作为参数,该数组的成员是一个个表示健值对的数组
    let mmap = new Map([
    [123,'健值1'],
    [456,'健值2']
    ])
    console.log(mmap.get(123)) //健值1
    //注意:只有针对同一个对象的引用,Map结构才将其视为同一个健。
    mmap.set(['a'],123)
    console.log(mmap.get(['a']))//undefined 此处的['a']是两个内容相同的不同对象。
    let obb = ['a']
    mmap.set(obb,123)
    console.log(mmap.get(obb))//123
    //map数据结构方法
    keys():返回键名的遍历器
    values():返回键值的遍历器
    entries():返回健值对的遍历器
    forEach():使用回调函数遍历每个成员
    for(let xx of mmap.keys()){
    console.log(xx) //123,456,['a'],['a']
    }
    for(let xx of mmap.values()){
    console.log(xx) //健值1,健值2,123,123
    }
    for(let xx of mmap.entries()){
    console.log(xx) // [123, "健值1"],[456, "健值2"],[Array(1), 123],[Array(1), 123]
    }
    //v代表当前遍历到的健值对的健值
    //k代表当前遍历到的健值对的键名
    mmap.forEach((v,k) =>{
    console.log(v,k)//健值1 123 健值2 456 123 ["a"] 123 ["a"]
    })
    //map结构转化为数组(最简单的使用扩展运算符 ...神奇三点)
    const map = new Map([
    [1,'one'],
    [2,'two'],
    [3,'three']
    ])
    let ree = [...map.keys()]
    console.log(ree) //[1, 2, 3]
    let reee = [...map.values()]
    console.log(reee) //["one", "two", "three"]
    let reeee = [...map.entries()] // [...map]
    console.log(reeee) //[Array(2), Array(2), Array(2)]
    let bxc = Array.from(map)//[Array(2), Array(2), Array(2)] 也可将map结构转化为数组
    for(x of map){
    console.log(x). //[1,'one'],[2,'two'], [3,'three']
    }
    //传统的数组 字典遍历用forin循环遍历,x代表数组中的下标键名。
    //对于set结构和map结构必须用of遍历,x此时代表的是键值。


  9. calss animal{
    //构造函数,会在类被实例化的时候自动执行
    //一般来讲,需要定义的属性,都声明在constructor里面
    constructor(){
    this.weight = ‘重量’;
    this.color = ‘颜色’;
    }
    //创建类的时候,方法之间不需要逗号或分号
    //类里面的方法不需要用function声明
    move(){
    console.log(‘会动’)
    }
    //通过类创建对象
    let map = new animal();
    Class fish extends animal{
    constructor(){
    super();//如果继承父类,需要添加属性,必须先声明super方法。
    this.sao = ’21’;
    //super当作对象使用的时候,指向的是父类的原型(prototype) 说白了,super对象指向的就是父类,可以通过super对象得到父类中的方法
    super.move();
    }}

  10. ReactNative中的platform选择
    const platformText = Platform.select({
    ios:' 我是ios',
    android:'我是android'
    })
    <Text> {platformText} </Text>

  11. state和props
    state:我们使用两种数据来控制一个组件,props和state。props是在父组件中指定,而且一经指定,在被指定的组件的生命周期中则不再改变。对于需要改变的数据,我们需要使用state。
    一般来说,你需要在constructor中初始化state,然后再需要修改时调用setState方法。

  12. Promise.
    //Promise。简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果。
    var p = new Promise((resolve,reject)=>{
    setTimeout(() => {
    //resolve表示将promise对象的状态变为成功,而后会执行后续的处理流程
    // reject()// 表示失败
    resolve() //表示成功
    }, 2000);
    })
    .then((x)=>{//then方法会等promise对象状态变为结束后执行
    // console.log(x)
    console.log('淘宝11')
    })
    Fetch本身也属于promise的一种对象
    fetch('http:www.baidu.com',{
    methods:'POST',
    body:'sasasasas'
    }).then(x=>{
    })

  13. 除了系统的循环组件,最基本的循环组件展示
    constructor(props){
    super(props)
    this.state = {
    ary:[1,2,3,4],
    }
    render(){
    let alltitle = []
    this.state.ary.map((x)=>{
    alltitle.push(<Text>标题:{x}</Text>)
    })
    return(
    {alltitle}. //循环展示组件
    )}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343