[技术博客]微信小程序开发中遇到的两个问题的解决
IDE介绍
微信web开发者工具
前端语言
微信小程序使用的语言为wxml和wss,使用JSON以及js逻辑进行页面之间的交互。与网页的html和css略有不同,微信小程序在此基础上添加了自己的改进,变得更加具有微信特色。
实现添加标签时自动联想
前端wxml中采用了wx:if
来控制标签是否显示。我们在js中定义了一个大的字典来存放每个变量,并且在每个变量中跟了一个布尔值来判断是否显示。
wxml代码中首先对搜索的联想结果判断了是否显示,并且对标签也判断了是否显示。wxml代码如下:
<input type='text' class = "ipsel" confirm-type='search' bindinput='input1' bindconfirm='confirm1' bindblur='noblur' value = "{{tei}}"></input>
<view wx:for="{{hosList}}" wx:for-item="h">
<view data-text = "{{h.name}}" wx:if="{{h.show}}" catchtap='clicsho'>{{h.name}}</view>
</view>
<view class="comment-btn">
<button
wx:for="{{riderCommentList}}"
wx:for-item="item"
wx:key="item.index"
bindtap="checkboxChange"
data-value="{{item.value}}"
data-index="{{index}}"
checked="{{item.selected}}"
class="btn {{item.selected ? 'btn-selected' : ''}}"
wx:if = "{{item.selected}}">
{{item.title}}❌
</button>
</view>
在js逻辑中,我们每次得到输入框中的文字有变化,就调用input1
函数,在这个函数中,我们将读到的数据存进this.data
中,并且根据这个进行搜索。
input1: function (e) {
this.setData
({
tei: e.detail.value
})
this.serch(e.detail.value)
},
搜索过程如下:我们在标签列表中按照关键词搜索serch
域,如果找到了,那么将这个标签的布尔值赋值为true
,这样他就会显示在标签里。
serch: function (key) {
var that = this;
var arr = [];
console.log("assss"+key)
for (let i in that.data.hosList1) {
that.data.hosList1[i].show = false;
if (that.data.hosList1[i].serch.indexOf(key) > 0) {
that.data.hosList1[i].show = true;
arr.push(that.data.hosList1[i])
}
}
console.log(arr)
this.setData({
hosList: arr,
})
},
点击搜索结果后,把显示的所有联想结果关掉,并将输入框中内容清空,同时,将选择的标签的布尔域设置为true。
clicsho: function (e) {
var that = this;
console.log(e);
var tti = e.currentTarget.dataset.text;
for(var i = 0; i< that.data.riderCommentList.length; i++)
{
if (that.data.riderCommentList[i].value == tti)
{
let string = "riderCommentList["+i+"].selected";
that.setData
({
[string]: true,
})
}
}
this.setData
({
tei: "",
hosList: []
})
},
解决前端页面传参时保留字无法传递问题
前端页面传参时,通过json.stringify来传递参数,这个时候,如果遇到了传递的字符串中存在&、!
等情况的时候,传递过去的值就会在此处断掉,导致进入下一个页面报错。
var para = JSON.stringify(can);
wx.navigateTo({
url: '../homeson/homeson?info=' + para,
})
解决方法
传参前加入下面代码:
para = encodeURIComponent(para)
下一页面调用前加入下面代码:
var kk = decodeURIComponent(options.info)
this.data.info = JSON.parse(kk);
通过encodeURIComponent
可以将字符串中的保留字进行编码,用特定的编码替换,从而在参数传递过程中解决保留字无法传递问题,decodeURIComponent
可以将编码后的保留字替换回来,从而在显示的时候按照传递前进行显示。
[技术博客]微信小程序开发中遇到的两个问题的解决的更多相关文章
- 技术博客——微信小程序UI的设计与美化
技术博客--微信小程序UI的设计与美化 在alpha阶段的开发过后,我们的小程序也上线了.看到自己努力之后的成果大家都很开心,但对比已有的表情包小程序,我们的界面还有很大的提升空间,许多的界面都是各个 ...
- 技术博客--微信小程序canvas实现图片编辑
技术博客--微信小程序canvas实现图片编辑 我们的这个小程序不仅仅是想给用户提供一个保存和查找的平台,还希望能给用户一个展示自己创意的舞台,因此我们实现了图片的编辑部分.我们对对图片的编辑集成了很 ...
- 技术博客——微信小程序的架构与原理
技术博客--微信小程序的架构与原理 在两个月的微信小程序开发过程中,我曾走了不少弯路,也曾被很多现在看来十分可笑的问题所困扰.这些弯路与困扰,基本上都是由于当时对小程序的架构理解不够充分,对小程序的原 ...
- [技术博客] 微信小程序的formid获取
微信小程序的formid获取 formId的触发 微信小程序可以通过收集用户的formid,获取formid给用户主动推送微信消息.获取formid有两个途径,一个是触发一次表单提交,或者触发一次支付 ...
- [技术博客]微信小程序审核的注意事项及企业版小程序的申请流程
关于小程序审核及企业版小程序申请的一些问题 微信小程序是一个非常方便的平台.由于微信小程序可以通过微信直接进入,不需要下载,且可使用微信账号直接登录,因此具有巨大的流量优势.但是,也正是因为微信流量巨 ...
- 总结微信小程序开发中遇到的坑
总结微信小程序开发中遇到的坑,一些坑你得一个一个的跳啊,/(ㄒoㄒ)/~~ 1,页面跳转和参数传递实例 首先说一下我遇到的需求有一个我的消息页面,里面的数据都是后端返回的,返回的数据大致如下,有一个是 ...
- 解决微信小程序开发中wxss中不能用本地图片
微信小程序开发中wxss中不能用本地图片,我们可以用将我们的图片传到服务器上,然后直接引用在线地址.但是当我们没有服务器时,我们可以用"图床",这个具体可以百度.这里我们用第二种方 ...
- 微信小程序开发中的二三事之网易云信IMSDK DEMO
本文由作者邹永胜授权网易云社区发布. 简介 为了更好的展示我们即时通讯SDK强悍的能力,网易云信IM SDK微信小程序DEMO的开发就提上了日程.用产品的话说就是: 云信 IM 小程序 SDK 的能力 ...
- 关于微信小程序开发中遇到的缺少game.json问题的解决
一.小程序开发的两种选项 ①小游戏开发:内部对应的入口配置文件为game.json丶game.wxml之类的文件或者项目. ②小程序开发:内部对应的入口配置文件为app.json丶app.wxml之类 ...
随机推荐
- Django:RestFramework之-------视图
10.视图 GenericAPIView封装一些方法,将这些方法返回值放在类变量位置上. 1.GenericAPIView视图示例:不怎么用 from api.utils.serializers.pa ...
- postgresql怎么导入数据库
1.切换到postgres用户 : sudo su - postgres 2.在shell命令行下,创建数据库exampledb,并指定所有者为dbuser : sudo -u postgres - ...
- Python之路(第四十四篇)线程同步锁、死锁、递归锁、信号量
在使用多线程的应用下,如何保证线程安全,以及线程之间的同步,或者访问共享变量等问题是十分棘手的问题,也是使用多线程下面临的问题,如果处理不好,会带来较严重的后果,使用python多线程中提供Lock ...
- springboot异常处理方式
一.异常处理思路 异常捕获的是unchecked型异常,因为checked异常在代码中年已经处理过,当然是在使用try-catch处理.这里首先使用ExceptionHandler捕获全局异常,这样如 ...
- Linux 常用命令(根据自己的理解随时更新)
1. linux 目录解释系统启动必须: /boot:存放的启动 Linux 时使用的内核文件,包括连接文件以及镜像文件. /etc:存放所有的系统需要的配置文件和子目录列表,更改目录下的文件可能会导 ...
- GRUB配置与应用,启动故障分析解决
一.GRUB启动位置 GRUB是现今大多数Linux系统采用的自举程序,这里先来看一下Linux的程序顺序: 执行顺序 动作 固件Firmware(CMOS/BIOS) → POST(Pwer ...
- C#程序 -- 以管理员权限运行
阅读目录 一.判断程序是否以管理员身份运行 C#程序以管理员权限运行 在Vista 和 Windows 7 及更新版本的操作系统,增加了 UAC(用户账户控制) 的安全机制,如果 UAC 被打开,用户 ...
- utf8mb4版本设置django
'OPTIONS':{ 'init_command':"SET sql_mode='STRICT_TRANS_TABLES'", 'charset':'utf8mb4',
- 项目Alpha冲刺(团队)-博客汇总
格式描述 课程名称:软件工程1916|W(福州大学) 作业要求:项目Alpha冲刺(团队) 团队名称:为了交项目干杯 作业目标:集中记录所有敏捷冲刺日志的集合 团队信息 队员学号 队员姓名 个人博客地 ...
- python应用-猜数字
""" 猜数字游戏(电脑给数字人猜) Author:罗万财 Date:2017-6-3 """ from random import ran ...