微信小程序let和var以及const有什么区别

微信小程序let和var以及const有什么区别,第1张

您好!很高兴能为您解答,  在JavaScript中有三种声明变量的方式:var、let、const。 var:声明全局变量,换句话理解就是,声明在for循环中的变量,跳出for循环同样可以使用。 [JavaScript] 纯文本查看 复制代码 ? 1 2 3 4 5 for(var i=0i<=1000i++){ var sum=0sum+=i} alert(sum)声明在for循环内部的sum,跳出for循环一样可以使用,不会报错正常d出结果 let:声明块级变量,即局部变量。 在上面的例子中,跳出for循环,再使用sum变量就会报错 注意:必须声明'use strict'后才能使用let声明变量否则浏览并不能显示结果 const:用于声明常量,也具有块级作用域 const PI=3.14

swiper组件的常用属性

属性     类型默认值 说明

indicator-dots     boolean false 是否显示面板指示点

indicator-color    color rgba(0,0,0,.3) 指示点颜色

indicator-active-color   color #O000oo 当前选中的指示点颜色

autoplay     boolean false 是否自动切换

interval      number 5000    自动切换时间间隔

circular     boolean false    是否采用衔接滑动`

二、按钮

通过type属性指定按钮颜色类型

<button>普通按钮</button>

<button type="primary">主色调按钮</button>

<button type="warn">警告按钮</button>

size="mini" 小尺寸按钮同一行

<button size="mini">普通按钮</button>

<button type="primary" size="mini">主色调按钮</button>

<button type="warn" size="mini">警告按钮</button>

plain 镂空按钮

<button plain>普通按钮</button>

<button type="primary" plain>主色调按钮</button>

<button type="warn" plain>警告按钮</button>

  data: {

    inputVal : '',

    storageVal:''

  },

  bindkeyInput: function (e) {

    let {detail: { value }  } = e

    this.setData({

      inputVal: value

    })

  },

  cun:function(){

    let arr=['name','age','sex']

    let i =Math.floor(Math.random()*(2-0+1)+0)

    /* 异步取缓存的值必须在回调函数里面取 同的直接=即可 */

    wx.setStorage({

      key:'myname',

      data:'我是小超人',

      success:function(){

        console.log('我成功了')

      }

    })

    /* 同步的存起来 */

    /* 相同的key会把值覆盖 */

    /* wx.setStorageSync('username', this.data.inputVal) */

    wx.setStorageSync(arr[i],this.data.inputVal)

  },

  qu:function(){

    this.setData({

      /* 同步的取缓存的值 */

      /* 浏览器中的缓存存进去的都是字符串,小程序里的缓存可以存字符串,数组和对象 */

      /* undefined存进去是字符串 null存进去是null类型 Symbol存进去是Symbol类型 */

      /* storageVal:wx.getStorageSync('username') */

       storageVal:wx.getStorageSync('sex')

    })

  },

  delSex:function(){

    /* 同步删除指定的某一个缓存 */

    wx.removeStorageSync('sex')

  },

  delAll:function(){

    wx.clearStorageSync()

  },

wxml内容:

<view bindtap="a" data-f="{{flag}}">123</view>

<!-- wx:for="{{数组}}" 循环需要绑定key wx:key="index"-->

<!-- 自带定义 item 表示数组的每一项 index 表示数组的索引 -->

<!-- 使用wx:for-item修改每一项值的key -->

<!-- 使用wx:for-index修改每一项值的index -->

<view wx:for="{{list}}" class="t" wx:key="i" 

    wx:for-item="r" wx:for-index="i"

    style="color:{{r.styFlag?'red':''}}"

    data-i="{{i}}"

    bindtap="choose"

>

    {{r.name}}--{{i}}

</view>

js内容:

data: {

        flag:1,

        list:['冰墩墩','雪融融','小泡菜'],

        list:[{

            name:'冰墩墩',

            styFlag:true

        },{

            name:'雪融融',

            styFlag:false

        },{

            name:'小泡菜',

            styFlag:false

        }]

    },

    choose:function(e){

        let { currentTarget:{ dataset:{i} } } = e

        /* 第一步获取点击的当前的内容的索引 */

        console.log(i)

        /* 排他 把所有的先置空 */

        this.data.list.forEach(r=>{

            r.styFlag = false

        })

        this.data.list[i].styFlag = true

        /* 数据变了 视图没变 必须要使用setData实现数据和视图的双向数据绑定 */

        this.setData({

            list:this.data.list

        })

    },

    a:function(e){

        console.log(e)

    },

效果:

wxml内容:

<button bindtap="go1" style="margin: 3px">张三</button>

<button bindtap="go2" style="margin: 3px">李四</button>

<button bindtap="go3" style="margin: 3px">24号</button>

<button bindtap="go4" style="margin: 3px">不带参数</button>

<button bindtap="goBack">返回上一级</button>

<!-- wx:if 和 wx:elif 以及wx:else之间不可以被其他的标签打断 -->

<block>

    <view wx:if="{{msg=='zhangsan'}}" class="t">欢迎回来主人</view>

    <view wx:elif="{{msg=='lisi'}}" class="t">家里水龙头没有坏不要过来</view>

    <view wx:elif="{{msg=='24'}}" class="t">您好欢迎为您服务</view>

    <view wx:else class="t">显示家里没人</view>

</block>

js内容:

Page({

    /**

     * 页面的初始数据

     */

    data: {

        msg:""

    },

    goBack:function(){

        wx.navigateBack()

    },

    /**

     * 生命周期函数--监听页面加载

     */

    onLoad: function (options) {

        console.log(options.name)

        /* 多次使用setData会影响性能 尽量把多次setData 使用一次setData来实现

        尽量少的使用setData来提高小程序的性能 */

        this.setData({

            msg:options.name

        })

        /* 如果名字叫张三 页面显示欢迎回来主人 */

        /* 如果名字叫李四 页面显示家里水龙头没有坏不要过来 */

        /* 如果名字叫24号 页面显示您好欢迎为您服务 */

        /* 都不是 显示家里没人 */

    },

    /**

     * 生命周期函数--监听页面初次渲染完成

     */

    onReady: function () {

    },

    /**

     * 生命周期函数--监听页面显示

     */

    onShow: function () {

    },

    /**

     * 生命周期函数--监听页面隐藏

     */

    onHide: function () {

    },

    /**

     * 生命周期函数--监听页面卸载

     */

    onUnload: function () {

    },

    /**

     * 页面相关事件处理函数--监听用户下拉动作

     */

    onPullDownRefresh: function () {

    },

    /**

     * 页面上拉触底事件的处理函数

     */

    onReachBottom: function () {

    },

    /**

     * 用户点击右上角分享

     */

    onShareAppMessage: function () {

    }

})

{

  "pages": [

    "pages/index/index",

    "pages/forpage/forpage",

    "pages/mypage/mypage",

    "pages/logs/logs",

    "pages/fenglei/fenglei"

  ],

  "window": {

    "backgroundTextStyle": "dark",

    "navigationBarBackgroundColor": "#FF0000",

    "navigationBarTitleText": "kw47page",

    "navigationBarTextStyle": "white"

  },

  "tabBar": {

    "color": "#fff",

    "selectedColor": "#FFCA28",

    "backgroundColor": "#000",

    "list": [{

      "pagePath": "pages/index/index",

      "text": "首页",

      "iconPath": "",

      "selectedIconPath": ""

    }, {

      "pagePath": "pages/logs/logs",

      "text": "日志",

      "iconPath": "",

      "selectedIconPath": ""

    }]

  },

  "style": "v2",

  "sitemapLocation": "sitemap.json"

}

效果图:


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11993354.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存