微信小程序开发技巧汇总


Posted in Javascript onJuly 15, 2019

1.全局变量的使用

每个小程序都需要在 app.js 中调用 App 方法注册小程序示例,绑定生命周期回调函数、错误监听和页面不存在监听函数等。
详细的参数含义和使用请参考 App 参考文档 。

整个小程序只有一个 App 实例,是全部页面共享的。开发者可以通过 getApp 方法获取到全局唯一的 App 示例,获取App上的数据或调用开发者注册在 App 上的函数。

我们在做小程序的时候往往需要大量的请求,而请求的域名也都是相同的,我们可以把域名储存到全局变量中,这样会方便后面请求域名的修改。(user_id、unionid、user_info之类经常用到的都可以放在全局变量中)

//app.js
App({
 globalData: {
  user_id: null,
  unionid:null,
  url:"https://xxx.com/index.php/Home/Mobile/",   //请求的域名
  user_info:null
 }
})

当在页面中使用时记得要引用下app.js,小程序已经提供了方法

//index.js
//获取应用实例
const app = getApp()  //获取app
//let url = app.globalData.url; //使用方法,可先定义或者直接使用app.globalData.url
wx.request({
  url: app.globalData.url + 'checkfirst', //就可以直接在这里调用
  method:'POST',
  header:{"Content-Type":"application/x-www-form/"}
  data:{},
  success:(res)=>{}

2.箭头函数的使用

当我们调用接口请求时要通过请求返回的数据改变页面数据经常要用到临时指针来保存this指针。

但如果使用ES6的箭头函数就可以避免

使用临时指针

onLoad: function (options) {
  let that = this //保存临时指针
  wx.request({
   url: url + 'GetCouponlist',
   method: 'POST',
   header: { 'Content-Type': 'application/x-www-form-urlencoded' },
   data: { },
   success(res) {
    that.setData({  //使用临时指针
     coupon_length:res.data.data.length
    })
   }
  })

使用ES6箭头函数 ( ) => {}

success:(res) => {
    this.setData({  //此时this仍然指向onLoad
     coupon_length:res.data.data.length
    })
   }

3.HTTP请求方法的封装

在小程序中http请求是很频繁的,但每次都打出wx.request是很烦的,而且代码也是冗余的,所以我们要把他封装起来
首先要在utils文件夹中新建一个js,我命名为request.js,在里面封装出post和get的请求,记得最后要声明出来

//封装请求
const app = getApp()
let host = app.globalData.url

/**
 * POST 请求
 * model:{
 * url:接口
 * postData:参数 {}
 * doSuccess:成功的回调
 *  doFail:失败回调
 * }
 */
function postRequest(model) {
 wx.request({
  url: host + model.url,
  header: {
   "Content-Type": "application/x-www-form-urlencoded"
  },
  method: "POST",
  data: model.data,
  success: (res) => {
   model.success(res.data)
  },
  fail: (res) => {
   model.fail(res.data)
  }
 })
}

/**
 * GET 请求
 * model:{
 *  url:接口
 *  getData:参数 {}
 *  doSuccess:成功的回调
 *  doFail:失败回调
 * }
 */
function getRequest(model) {
 wx.request({
  url: host + model.url,
  data: model.data,
  success: (res) => {
   model.success(res.data)
  },
  fail: (res) => {
   model.fail(res.data)
  }
 })
}

/**
 * module.exports用来导出代码
 * js中通过 let call = require("../util/request.js") 加载
 */
module.exports = {
 postRequest: postRequest,
 getRequest: getRequest
}

这一步非常重要记得添加!

module.exports = {
postRequest: postRequest,
getRequest: getRequest
}

使用时就在相应的页面顶部调用,Page外部噢

let call = require("../../utils/request.js")

使用的时候↓

get

//获取广告图
  call.getRequest({
   url:'GetAd',
   success:(res)=>{   //箭头函数没有指针问题
    this.setData({
     urlItem: res.data
    })
   }
  })

post

call.postRequest({
   url: 'addorder',
   data: {
    shop_id: that.data.shop_id,
    user_id: app.globalData.user_id,
    coupon_sn: that.data.coupon_sn,
    carType: that.data.car_type,
    appointtime: that.data.toTime
   },
   success:(res)=>{
    console.log(res)
    wx.navigateTo({
     url: '../selectPay/selectPay?order_sn=' + res.data.order_sn + '&fee=' + res.data.real_pay + "&order_id=" + res.data.order_id,
    })
   }
  })

4.搜索input中,如何点击搜索按钮进行搜索及按钮样式修改

正常我们会在搜索框中加入一个搜索按钮,点击进行搜索,但是小程序不是操作dom的,所以是无法直接获取到input中的值,所以要通过另外的方法进行搜索。

(1)通过input组件中的bindconfirm属性(confirm-type="search" 可将软键盘的完成按钮改为“搜索”)

<input class='search_input' type='text' confirm-type='search' bindconfirm='toSearch' ></input>
//js部分
toSearch(e){
 console.log(e.detail.value) //e.detail.value 为input框输入的值
}

(2)利用form表单的提交,来完成点击按钮的提交(input需要添加name属性)

搜索按钮

微信小程序开发技巧汇总

利用button代替form的表单提交(form-type="submit"),注意用view不行,必须用button

需要自己修改button的默认样式(button的边框要在button::after中修改)

//wxml部分
<form bindsubmit="formSubmit" bindreset="formReset">
 <input class='search_input' type='text' confirm-type='search' name="search" bindconfirm='toSearch' >
 <button class='search_btn' form-type='submit'>搜索</button></input>
</form>
//js部分
formSubmit(e){
 console.log(e.detail.value.search) //为输入框的值,input记得添加name属性
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
为数据添加append,remove功能
Oct 03 Javascript
Javascript倒计时页面跳转实例小结
Sep 11 Javascript
JavaScript实现的一个计算数字步数的算法分享
Dec 06 Javascript
javascript数据结构与算法之检索算法
Apr 04 Javascript
javascript检测两个数组是否相似
May 19 Javascript
详解angularJs中关于ng-class的三种使用方式说明
Jun 02 Javascript
基于JS实现移动端左滑删除功能
Jul 28 Javascript
canvas+gif.js打造自己的数字雨头像的示例代码
Oct 26 Javascript
修改vue+webpack run build的路径方法
Sep 01 Javascript
jQuery高级编程之js对象、json与ajax用法实例分析
Nov 01 jQuery
vue2.0 获取从http接口中获取数据,组件开发,路由配置方式
Nov 04 Javascript
Vue实现购物车实例代码两则
May 30 Javascript
微信小程序中如何计算距离某个节日还有多少天
Jul 15 #Javascript
微信小程序基础教程之worker线程的使用方法
Jul 15 #Javascript
使用vue-router在Vue页面之间传递数据的方法
Jul 15 #Javascript
微信小程序在其他页面监听globalData中值的变化
Jul 15 #Javascript
vue中filters 传入两个参数 / 使用两个filters的实现方法
Jul 15 #Javascript
微信小程序全局变量改变监听的实现方法
Jul 15 #Javascript
vue draggable resizable 实现可拖拽缩放的组件功能
Jul 15 #Javascript
You might like
mysq GBKl乱码
2006/11/28 PHP
Smarty局部缓存的几种方法简介
2014/06/17 PHP
php中mail函数发送邮件失败的解决方法
2014/12/24 PHP
php中静态类与静态变量用法的区别分析
2015/01/15 PHP
PHP+MySQL存储数据常见中文乱码问题小结
2016/06/13 PHP
Node.js中AES加密和其它语言不一致问题解决办法
2014/03/10 Javascript
For循环中分号隔开的3部分的执行顺序探讨
2014/05/27 Javascript
jquery中filter方法用法实例分析
2015/02/06 Javascript
JavaScript中Function详解
2015/02/27 Javascript
javascript实现简单的二级联动
2015/03/19 Javascript
jquery+html5制作超酷的圆盘时钟表
2015/04/14 Javascript
原生JavaScript编写canvas版的连连看游戏
2016/05/29 Javascript
JavaScript中setter和getter方法介绍
2016/07/11 Javascript
如何在Angular.JS中接收并下载PDF
2016/11/26 Javascript
nodejs个人博客开发第七步 后台登陆
2017/04/12 NodeJs
微信小程序简单实现form表单获取输入数据功能示例
2017/11/30 Javascript
微信小程序实现折叠展开效果
2018/07/19 Javascript
深入剖析JavaScript instanceof 运算符
2019/06/14 Javascript
node.js文件操作系统实例详解
2019/11/05 Javascript
原生js无缝轮播插件使用详解
2020/03/09 Javascript
[04:09]显微镜下的DOTA2第十二期—NaVi美如画的团战
2014/06/23 DOTA
ssh批量登录并执行命令的python实现代码
2012/05/25 Python
使用Python操作MySQL的一些基本方法
2015/08/16 Python
Python基于xlrd模块操作Excel的方法示例
2018/06/21 Python
Python3标准库之functools管理函数的工具详解
2020/02/27 Python
如何通过python实现IOU计算代码实例
2020/11/02 Python
党员创先争优活动总结
2014/05/04 职场文书
二年级班级文化建设方案
2014/05/10 职场文书
武夷山导游词
2015/02/03 职场文书
2015年数学教研组工作总结
2015/05/23 职场文书
朋友圈早安励志语录!
2019/07/08 职场文书
Vue Element UI自定义描述列表组件
2021/05/18 Vue.js
万能密码的SQL注入漏洞其PHP环境搭建及防御手段
2021/09/04 SQL Server
PHP获取学生成绩的方法
2021/11/17 PHP
vue-cli3.0修改打包后的文件名和文件地址,打包后本地运行报错解决
2022/04/06 Vue.js
Win10加载疑难解答时出错发生意外错误的解决方法
2022/07/07 数码科技