热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

微信小程序的注意点(亲测实用)

微信小程序虽然便捷,但是在开发阶段,坑还是很多的。以下是我最近写小程序总结的一些小心得,望参考一二。1、wx:if条件判断当判断的内容是由多个组件标签组合的,则需要使用<block&g

微信小程序虽然便捷,但是在开发阶段,坑还是很多的。以下是我最近写小程序总结的一些小心得,望参考一二。

1、wx:if条件判断

当判断的内容是由多个组件标签组合的,则需要使用标签

if="{{true}}">
  
   view1 
   view2 

  2、引入iconfont时,在app.wxss做全局引用,但是这个全局仅局限于page里面的页面,不包括组件,如果组件需要引入iconfont,需要在每个组件的wxss引入

app.wxss:全局引入

@import 'iconfont.wxss';

  单个引入

@import '../../../iconfont.wxss';

  3、在使用tabbar时,在另一个页面需要跳转到tabbar所在页面,并关闭其他非tabbar页面,一般使用wx.switchTab去跳转,但是页面不会去刷新,

   而reLaunch()则是先关闭了所有页面,再跳转到指代的页面,会去刷新

  4、在js中,初始化时在data定义的初始值为对象或者数组时,在接下来的修改data时,会麻烦点。需要把需要修改的变量去赋值给一个变量,在使用this.setData()的时候,需要给这个变量加上中括号,具体写法如下红字所示:

data: { 
    circleId: '',
    data: {},
    commentData: {},
    isComment: false,
    isCollect: false,
    circleid: '',
    comment: '',
    curPage: 0,
    pageSize: 10,
    commentId: 0,
    commentDataShow: '展开评论',
    albumId: ''
  },
 // 二级评论的点赞
  loveComment2(e) {
    console.log(e)
    let dataset = e.currentTarget.dataset
    let type = dataset.commenttype
    let commentId = dataset.commentid
    let index = dataset.index
    let index2 = dataset.index2
    let isLoveStr = `commentData[${index}].secondComments[${index2}].secondIsLove`
    let secOndCommentCountStr= `commentData[${index}].secondComments[${index2}].secondCommentCount`
    let secondIsLove = dataset.secondislove
    let secondCommentCount = dataset.secondcommentcount

    if (secondIsLove) {
      comment.cancelLoveComment(commentId, type).then(res => {
        if (res.status == 'SUCCESS') {
          this.setData({
            [isLoveStr]: 0,
            [secondCommentCountStr]: secondCommentCount - 1 })
        }
      })
    } else {
      comment.loveComment(commentId, type).then(res => {
        if (res.status == 'SUCCESS') {
          this.setData({
            [isLoveStr]: 1,
            [secondCommentCountStr]: secondCommentCount + 1 })
        }
      })
    }
  },

  5、将不需要刷新的数据放到onLoad中执行,将不需要刷新的数据放到onShow中执行

  6、微信小程序自定义组件pageLifetimes和lifetimes的区别

    lifetimes:指的是组件的生命周期,pageLifetimes:指的是组件页面的生命周期

    如果tabbar页面使用了组件,还想在切换的时候及时刷新页面,组件初始化放在pageLifetimes中的show中

    详见官方文档:https://developers.weixin.qq.com/miniprogram/dev/framework/custom-component/component.html?search-key=%E6%9E%84%E9%80%A0%E5%99%A8

  

 

 

 

 


推荐阅读
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • 本文介绍了计算机网络的定义和通信流程,包括客户端编译文件、二进制转换、三层路由设备等。同时,还介绍了计算机网络中常用的关键词,如MAC地址和IP地址。 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • Python实现变声器功能(萝莉音御姐音)的方法及步骤
    本文介绍了使用Python实现变声器功能(萝莉音御姐音)的方法及步骤。首先登录百度AL开发平台,选择语音合成,创建应用并填写应用信息,获取Appid、API Key和Secret Key。然后安装pythonsdk,可以通过pip install baidu-aip或python setup.py install进行安装。最后,书写代码实现变声器功能,使用AipSpeech库进行语音合成,可以设置音量等参数。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • C# 7.0 新特性:基于Tuple的“多”返回值方法
    本文介绍了C# 7.0中基于Tuple的“多”返回值方法的使用。通过对C# 6.0及更早版本的做法进行回顾,提出了问题:如何使一个方法可返回多个返回值。然后详细介绍了C# 7.0中使用Tuple的写法,并给出了示例代码。最后,总结了该新特性的优点。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
author-avatar
大道废_796
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有