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


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 相关文章推荐
简洁短小的 JavaScript IE 浏览器判定代码
Mar 21 Javascript
JavaScript中两种链式调用实现代码
Jan 12 Javascript
jquery插件珍藏(图片局部放大/信息提示框)
Jan 08 Javascript
js支持键盘控制的左右切换立体式图片轮播效果代码分享
Aug 26 Javascript
jquery实现简单实用的弹出层效果代码
Oct 15 Javascript
jQuery+CSS实现一个侧滑导航菜单代码
May 09 Javascript
js操作XML文件的实现方法兼容IE与FireFox
Jun 25 Javascript
Node.js利用js-xlsx处理Excel文件的方法详解
Jul 05 Javascript
vue+VeeValidate 校验范围实例详解(部分校验,全部校验)
Oct 19 Javascript
微信小程序实现pdf、word等格式文件上传的方法
Sep 10 Javascript
Jquery使用each函数实现遍历及数组处理
Jul 14 jQuery
vue 通过base64实现图片下载功能
Dec 19 Vue.js
微信小程序学习笔记之表单提交与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
JS中encodeURIComponent函数用php解码的代码
2012/03/01 PHP
php简单备份与还原MySql的方法
2016/05/09 PHP
PHP常用字符串函数小结(推荐)
2018/08/05 PHP
详解在YII2框架中使用UEditor编辑器发布文章
2018/11/02 PHP
javaScript call 函数的用法说明
2010/04/09 Javascript
基于jquery的合并table相同单元格的插件(精简版)
2011/04/05 Javascript
jQuery AjaxQueue改进步骤
2011/10/06 Javascript
密码强度检测效果实现原理与代码
2013/01/04 Javascript
javascript阻止scroll事件多次执行的思路及实现
2013/11/08 Javascript
JS实现CheckBox复选框全选全不选功能
2015/05/06 Javascript
JS实现部分HTML固定页面顶部随屏滚动效果
2015/12/24 Javascript
js 动态生成html 触发事件传参字符转义的实例
2017/02/14 Javascript
Javascript操作dom对象之select全面解析
2017/04/24 Javascript
在百度搜索结果中去除掉一些网站的资料(通过js控制不让显示)
2017/05/02 Javascript
原生JS实现的多个彩色小球跟随鼠标移动动画效果示例
2018/02/01 Javascript
手把手教你用Node.js爬虫爬取网站数据的方法
2018/07/05 Javascript
vue实现点击选中,其他的不选中方法
2018/09/05 Javascript
开发一个Parcel-vue脚手架工具(详细步骤)
2018/09/22 Javascript
vue点击按钮动态创建与删除组件功能
2019/12/29 Javascript
Element-UI 使用el-row 分栏布局的教程
2020/10/26 Javascript
[52:09]2014 DOTA2华西杯精英邀请赛 5 25 NewBee VS DK第二场
2014/05/26 DOTA
[02:57]2014DOTA2国际邀请赛-观众采访
2014/07/19 DOTA
wxPython中文教程入门实例
2014/06/09 Python
Python实现Linux下守护进程的编写方法
2014/08/22 Python
Python字符串切片操作知识详解
2016/03/28 Python
Python中property函数用法实例分析
2018/06/04 Python
pytorch 数据集图片显示方法
2018/07/26 Python
python使用response.read()接收json数据的实例
2018/12/19 Python
美国批发零售网站:GearXS
2016/07/26 全球购物
美国最大的船只买卖在线市场:Boat Trader
2018/08/04 全球购物
sleep()方法和wait()方法的区别是什么
2012/11/17 面试题
2015年业务工作总结范文
2015/04/10 职场文书
红色经典电影观后感
2015/06/18 职场文书
施工安全协议书
2016/03/22 职场文书
4种方法python批量修改替换列表中元素
2022/04/07 Python
利用Redis实现点赞功能的示例代码
2022/06/28 Redis