微信小程序学习笔记之跳转页面、传递参数获得数据操作图文详解


Posted in Javascript onMarch 28, 2019

本文实例讲述了微信小程序学习笔记之跳转页面、传递参数获得数据操作。分享给大家供大家参考,具体如下:

前面一篇介绍了微信小程序表单提交与PHP后台数据交互处理。现在需要实现点击博客标题或缩略图,跳转到博客详情页面。

微信小程序学习笔记之跳转页面、传递参数获得数据操作图文详解

开始想研究一下微信小程序的web-view组件跳转传参,把网页嵌入到小程序,结果看到官方文档的一句话打消了念头,因为没有认证......

微信小程序学习笔记之跳转页面、传递参数获得数据操作图文详解

【方法一 使用navigator组件跳转传参】

前台博客列表页面data.wxml:(后台数据交互参考上一篇)

<view wx:for="{{artinfo}}" wx:for-item="artinfo">
  <view>
    <navigator url="/pages/detial/detial?article_id={{artinfo.article_id}}" >
     {{artinfo.article_title}}
    </navigator>
  </view>
  <navigator url="/pages/detial/detial?article_id={{artinfo.article_id}}" >
   <image src="{{artinfo.thumbnail}}"></image>
  </navigator>
</view>

前台博客详情页面detail.js:

Page({
 onLoad: function (options) { //options:页面跳转所传的参数
  var that = this
  wx.request({
   url: 'https://www.msllws.top/Getdata/detial',
   data: {
    'article_id': options.article_id
   },
   method: 'POST',
   header: {
    'Content-Type': 'application/x-www-form-urlencoded'
   },
   success: function (res) {
    if (res.data.state == 1) {
     that.setData({
      artinfo: res.data.data
     })
    }else{
     wx.showToast({
      title: res.data.msg
     });
    }
   }
  })
 }
})

前台博客详情页面detail.wxml:

<view>{{artinfo.article_title}}</view>
<view>———————————————————————————</view>
<rich-text nodes="{{artinfo.article_content}}"></rich-text>

后台获取博客内容接口:(tp5)

public function detial()
 { 
   $arr = array('state'=>0,'msg'=>'','data'=>array());
   $article_id = $_POST['article_id'];
   if($article_id){
     $whe['article_id'] = $article_id;
     $artinfo = db('article')->field('`article_title`,`article_content`')->where($whe)->find();
     if($artinfo){
       $arr['state'] = 1;
       $arr['msg'] = 'success';
       $arr['data'] = $artinfo;
     }else{
       $arr['msg'] = '没有信息';
     }
   }else{
     $arr['msg'] = '参数错误';
   }
   echo json_encode($arr);die;
 }

实现效果如下:

微信小程序学习笔记之跳转页面、传递参数获得数据操作图文详解

【方法二 使用wx.navigateTo API跳转传参】

前台博客列表页面data.wxml:

(data-xxx:自定义参数属性,catchtap:绑定点击事件)

<view wx:for="{{artinfo}}" wx:for-item="artinfo">
  <view data-article_id="{{artinfo.article_id}}" catchtap="showDetial">
     {{artinfo.article_title}}
   </view>
  <view data-article_id="{{artinfo.article_id}}" catchtap="showDetial">
   <image src="{{artinfo.thumbnail}}"></image>
  </view>
</view>

前台博客列表页面data.js:

Page({
 onLoad: function () {
  var that = this
  wx.request({
   url: 'https://www.msllws.top/Getdata',
   headers: {
    'Content-Type': 'application/json'
   },
   success: function (res) {
    that.setData({
     artinfo: res.data
    })
   }
  })
 },
 showDetial: function (e) {
  var article_id = e.currentTarget.dataset.article_id;
  wx.navigateTo({
   url: '/pages/detial/detial?article_id=' + article_id
  })
 }
})

其他与方法一相同,可实现与方法一相同跳转传参。

希望本文所述对大家微信小程序开发有所帮助。

Javascript 相关文章推荐
jQuery toggle()设置CSS样式
Nov 05 Javascript
基于Jquery的仿照flash放大图片效果代码
Mar 16 Javascript
使用ajax+jqtransform实现动态加载select
Dec 01 Javascript
JavaScript中的call方法和apply方法使用对比
Aug 12 Javascript
jQuery基本选择器(实例及表单域value的获取方法)
May 20 Javascript
ReactNative短信验证码倒计时控件的实现代码
Jul 20 Javascript
Vue iview-admin框架二级菜单改为三级菜单的方法
Jul 03 Javascript
react在安卓中输入框被手机键盘遮挡问题的解决方法
Sep 03 Javascript
微信小程序开发之左右分栏效果的实例代码
May 20 Javascript
基于layui轮播图满屏是高度自适应的解决方法
Sep 16 Javascript
在vue-cli中引入lodash.js并使用详解
Nov 13 Javascript
vue页面跳转实现页面缓存操作
Jul 22 Javascript
微信小程序学习笔记之表单提交与PHP后台数据交互处理图文详解
Mar 28 #Javascript
深入理解es6块级作用域的使用
Mar 28 #Javascript
详解在网页上通过JS实现文本的语音朗读
Mar 28 #Javascript
详解React服务端渲染从入门到精通
Mar 28 #Javascript
微信小程序学习笔记之函数定义、页面渲染图文详解
Mar 28 #Javascript
JavaScript刷新页面的几种方法总结
Mar 28 #Javascript
Vue批量图片显示时遇到的路径被解析问题
Mar 28 #Javascript
You might like
php学习之运算符相关概念
2011/06/09 PHP
19个Android常用工具类汇总
2014/12/30 PHP
php使用redis的有序集合zset实现延迟队列应用示例
2020/02/20 PHP
javascript循环变量注册dom事件 之强大的闭包
2010/09/08 Javascript
jquery五角星评分插件示例分享
2014/02/21 Javascript
Nodejs极简入门教程(二):定时器
2014/10/25 NodeJs
深入解读JavaScript中的Iterator和for-of循环
2015/07/28 Javascript
js使用cookie记录用户名的方法
2015/11/26 Javascript
关于获取DIV内部内容报错的原因分析及解决办法
2016/01/29 Javascript
基于javascript实现表格的简单操作
2016/05/21 Javascript
Javascript类型系统之String字符串类型详解
2016/06/21 Javascript
jQuery UI结合Ajax创建可定制的Web界面
2016/06/22 Javascript
AngularJS入门教程之控制器详解
2016/07/27 Javascript
jQuery在header中设置请求信息的方法
2017/03/06 Javascript
详解Vue使用 vue-cli 搭建项目
2017/04/20 Javascript
原生JS实现$.param() 函数的方法
2018/08/10 Javascript
微信上传视频文件提示(推荐)
2018/11/22 Javascript
JS 自执行函数原理及用法
2019/08/05 Javascript
Node.js API详解之 vm模块用法实例分析
2020/05/27 Javascript
vue + el-form 实现的多层循环表单验证
2020/11/25 Vue.js
[01:02]2014 DOTA2国际邀请赛中国区预选赛 现场抢先看
2014/05/22 DOTA
[38:21]2018DOTA2亚洲邀请赛3月30日 小组赛A组 LGD VS Newbee
2018/03/31 DOTA
Python类方法__init__和__del__构造、析构过程分析
2015/03/06 Python
pandas 透视表中文字段排序方法
2018/11/16 Python
PyQT5 QTableView显示绑定数据的实例详解
2019/06/25 Python
如何基于python3和Vue实现AES数据加密
2020/03/27 Python
基于Tensorflow一维卷积用法详解
2020/05/22 Python
物流专业大学生求职信范文
2013/10/28 职场文书
领班岗位职责范文
2014/02/06 职场文书
建筑管理专业求职信
2014/07/28 职场文书
2014年大学宣传部工作总结
2014/12/19 职场文书
2015年教师节活动总结
2015/03/20 职场文书
火烧圆明园观后感
2015/06/03 职场文书
学习习近平主席讲话心得体会
2016/01/20 职场文书
springboot使用Redis作缓存使用入门教程
2021/07/25 Redis
工厂无线对讲系统解决方案
2022/02/18 无线电