微信小程序for循环以及页面跳转

微信小程序for循环以及页面跳转,第1张

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"

}

效果图:

CSDN博客名:ColorKin

尽量不要用缓存去写,四月份的时候写的那篇因为当时是侍芹新手,只会那么写

效果展示:点击编辑,进入编辑页

第一页编辑按钮:

 <view class="bj-btn" bindtap="redactGroup"  data-id="{{传递的悄谈禅启尘id}}">编辑</view>

redactGroup方法:

 options.currentTarget.dataset.前面自定义的名字

 redactGroup(options){

    let id = options.currentTarget.dataset.id 

        wx.navigateTo({

          url: '../redact_group/redact_group?id='  + id

        })

  }

第二页的onLoad函数来接收传递过来的id,然后再次请求获得数据

onLoad: function (options) {

   console.log("options-------",options.id)

   let _id = options.id

    this.函数名(_id)   

  },

1、在微信开发者工具中,打开app.json文件,在pages数组中增加show.wxml页面相关文件的代码,以加粗显示,代码如下:

{

"pages":[

"pages/index/index",

"pages/show/show",

"运禅pages/logs/logs"

],

"window":{

"backgroundTextStyle":"light",

"navigationBarBackgroundColor": "#ccc",

"navigationBarTitleText": "WeChat",

"navigationBarTextStyle":"black"

}

}

2、在index.wxml文件中,在类为usermotto的view组件中添加绑定属性catchtap='enterShow',以加粗显示,代码如下:

<!--index.wxml-->

<view class="container">

<view class="userinfo">

<button wx:if="{{!hasUserInfo &&canIUse}}" open-type="getUserInfo" bindgetuserinfo="getUserInfo">获取头像昵称 </button>

<block wx:else>

<image bindtap="bindViewTap" class="userinfo-avatar" src="{{userInfo.avatarUrl}}" background-size="cover"></image>

<text class="userinfo-nickname">{{userInfo.nickName}}</text>

</block>

</view>

<view class="usermotto" catchtap='enterShow'>

<text class="user-motto">{{motto}}</text>

</view>

</view>

3、在index.js文件中,将data中motto的值改为“点击进入”。编写实现跳转的自定义函数enterShow,加粗显示,代码如下:

//index.js

//获取应用实例

const app = getApp()

Page({

data: {

motto: '点击进入',

userInfo: {},

hasUserInfo: false,

canIUse: wx.canIUse('button.open-type.getUserInfo')

},

//事件处理函数

enterShow:function(){

wx.navigateTo({

url: '../show/show',

})

4、 在show.wxml中,输入跳转后页面显示的信息,代码如下:

<view>

<text>这是跳转后的页面</text>

</view>

5、然后在index.xwml中点击测试就可以了。

说明:在上面的页面跳转自定义函数enterShow中,也可以使用wx.redirectTo实现跳转。两者的区别:redirectTo将关闭当前页面,跳转到指定页面,页面左上角没有腊空返回的箭头按钮;而navigateTo将保留页面,跳转到指定页面,页面左上角有返回的箭头按钮。

扩展资料

其实在小程序后台很早就有个wx.openUrl的函数,普通开发者没有调用权限,这次微信给自家的小程序开放权限,旨在测试这一功能可能的风险。因为这一功能如果全部开放,将会给小程序用户带轮悄瞎来很大的安全隐患。居心不良的开发者可能会将用户引流至一些不安全页面。

小程序的审核难度也会变得很大。因为微信除了审核小程序本身的页面跳转和内容,还需要审核外链的链接,并且还不一定能够审核清楚。


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

原文地址:https://54852.com/yw/12565779.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2025-08-26
下一篇2025-08-26

发表评论

登录后才能评论

评论列表(0条)

    保存