微信小程序 + wepy快速开发
wepy官网:https://tencent.github.io/wepy/document.html,想要了解全面最好去官网,以下只是指出项目里常用地方。
1.页面跳转
(1)//有返回跳转
wepy.navigateTo({
url: "/pages/address_add"
});
(2)//无返回跳转
wepy.switchTab({
url: '/pages/shop_cart'
})
2.组件间通信
(1)由一个页面或组件对另一个组件中的方法的直接调用
this.$invoke('comAddress', 'getLocationInfo'); //第一个参数是调用指定组件的路径,第二个是调用的方法。
(2)由子组件发起向父组件调用某方法,如从组件comC发起,comB组件接收,然后page_A在接收
that.$emit('selectCode', that.code); //第一个参数是调用的方法,第二个是传过去的参数
(3)事件是由父组件发起,所有子组件都会收到此广播事件,除非事件被手动取消。如从page_A发起,comB组件接收,comB里的组件comC再接收
this.$broadcast()
3.数据 / 缓存
wepy.$store.dispatch({type: CHANGE_CART, payload: {goodCartList: that.cartList}});
4.页面与组件
首先组件最好放在 components 里,调用的方法和微信一样。然后页面也是和原生的微信小程序一样,最好是放在 pages包 里,然后在 app.wpy 创建一个页面,不过wepy没有和微信小程序一样有 .js,.json,.wxml,.wxss文件,它是把这四个文件结合在一个后面带有 .wpy 文件里,结构和区别如下:
(1) 页面
<template>
<view>
<topicItem :countNum.sync="countNum" @showDownload.user="getShowDownload"></topicItem> //使用组件,countNum 为传入组件参数,加个 .sync 属于动态传值,否者属于静态传值,只能传String类型。
@showDownload.user 为子组件调用父页面的方法,.user
表明绑定用户自定义组件事件,通过$emit
触发
<view @tap="previewImage"></view> //区别:这里的事件不像原生小程序那样用要 bindtap='',这里用 @tap='',可以用 @tap.stop='' 阻止事件冒泡
</view>
</template>
<script>
import wepy from 'wepy';
import api from "@/api/api"; //调用后台接口统一放在这文件里
import TopicItem from "../../components/topic_item"; //导入组件
export default class SquareDetails extends wepy.page { //注意:这里是 page
config = {
navigationBarTitleText: '话题详情', //设置页面标题
usingComponents: {
"van-popup": "/components/vant-weapp/popup/index", //这是导入vant组件
}
};
components = {
topicItem: TopicItem, //左边是 template 里调用组件的名字,右边是 script 导入组件的名字,两边可以不一样
};
data = {
countNum:[]
}
onLoad(option) { //生命周期和上拉下拉加载和微信的一样
this.topicDetails();
}
async topicDetails() { //区别:调用后台接口的方法可以使用 async 表示异步请求,然后使用 await 等待接口返回数据
const json = await api.getTopicDetails(
query: {
id: xxxxx
}
}
if (json.data.code == "SUCCESS") {
//接口返回后的操作逻辑
let resData = json.data.data;
this.countNum = resData; //区别:这里不用像小程序那样要用 this.setData({xx:'aa'}) 赋值。只需要用 ‘=’ 号就可以了
this.$aplly(); //区别: 这里要调用 $apply() 才能把最新数据渲染到页面,不然页面显示的还是原来的值
}
)
methods = { //区别:页面或组件的方法和点击事件最好要写这里
previewImage(){
//操作逻辑
},
getShowDownload(a,b,c){ //这是子组件用 this.#emit('showDownload',a,b,c) 传过来的方法, a,b,c 是传过来的参数
//操作逻辑
}
}
}
</script>
<style lang="less">
.topic-item-container {
//css
}
</style> (2) 组件
<template>
<block wx:for="{{countNum}}" wx:for-index="index" wx:for-item="item" wx:key="index">
<view>{{item}}</view>
</block>
</template>
<script>
import wepy from 'wepy';
import {UPDATE_TOPIC} from "@/store/types";
export default class SquareDetails extends wepy.component { //注意:这里是 component
config = {
usingComponents: {
"van-field": "/components/vant-weapp/field/index" //调用 vant 组件
}
}; props = { //注意:这里组件用 props 接收父组件传过来的参数
countNum:{
type: Object,
default: [],
twoWay: true //注意:这里 twoWay 标识双向绑定,意思是当子组件的值改变时,父组件对应的值也随之改变
}
}
computed = { //这里可以使用 computed/watch 监听数据变化
tempTopicItemList() {
return wepy.$store.getState().topic.topicItemList;
},
}
updateIndexListStore() {
//逻辑操作 wepy.$store.dispatch({ //改变 store 里的值
type: UPDATE_TOPIC, payload: {
topicItemList: newTempTopicItemList
}
});
}
}
</script>
<style lang='less'>
// css
</style> (3) reducers //可以说是相当于微信小程序的 storageSync 吧
import {handleActions} from 'redux-actions';
import {CHANGE_TOPIC, UPDATE_TOPIC} from "../types"; const defaultState = {
topicItemList: []
}; export default handleActions({
[CHANGE_TOPIC](state, action) {
return {
...state,
topicItemList: action.payload.topicItemList
};
},
[UPDATE_TOPIC](state, action) {
return {
...state,
topicItemList: action.payload.topicItemList
};
},
}, defaultState);
微信小程序 + wepy快速开发的更多相关文章
- 微信小程序wepy框架开发资源汇总
开源项目 wepy-wechat-demo:基于wepy开发的仿微信聊天界面小程序 深大的树洞:基于wepy开发的树洞类微信小程序 wepy-demo-bookmall:微信小程序
- 微信小程序wepy开发循环wx:for需要注意
微信小程序wepy开发循环wx:for需要注意 item index值必须在wx:for之后使用 <view wx:for="{{tablist}}" class=" ...
- 【云开发】10分钟零基础学会做一个快递查询微信小程序,快速掌握微信小程序开发技能(轮播图、API请求)
大家好,我叫小秃僧 这次分享的是10分钟零基础学会做一个快递查询微信小程序,快速掌握开发微信小程序技能. 这篇文章偏基础,特别适合还没有开发过微信小程序的童鞋,一些概念和逻辑我会讲细一点,尽可能用图说 ...
- 微信小程序的功能开发工具跟公众号的差别,小程序是一种减负思维对简单APP是巨大打击
微信小程序的功能开发工具跟公众号的差别,小程序是一种减负思维对简单APP是巨大打击 摘要: 小程序和公众号最大的区别有如下四点:1.小程序没有粉丝,开发者在后台能看到的只能是累计用户访问数以及实时统计 ...
- 微信小程序_快速入门01
这段时间,嗯,大四课程已经结束了,工作也已经找到了,但是呢,到公司报道的时间还没到,哈哈,马上就开始人生的第一份工作了,怎么说确实有点期待~ 在这段时间一方面为第一份工作做各种准备,另一方面也没有停止 ...
- 微信小程序之蓝牙开发(详细读数据、写数据、附源码)
本文将详细介绍微信小程序的蓝牙开发流程(附源码)准备:微信只支持低功耗蓝牙也就是蓝牙4.0,普通的蓝牙模块是用不了的,一定要注意. 蓝牙可以连TTL接到电脑上,再用XCOM调试 一开始定义的变量 va ...
- 微信小程序--使用云开发完成支付闭环
微信小程序--使用云开发完成支付闭环 1.流程介绍 2. 代码实现和逻辑思想描述 云函数统一下单 对应云函数 unipay [CloudPay.unifiedOrder] 函数思路 : 调用云函数封装 ...
- Slog71_选取、上传和显示本地图片GET !(微信小程序之云开发-全栈时代3)
ArthurSlog SLog-71 Year·1 Guangzhou·China Sep 12th 2018 ArthurSlog Page GitHub NPM Package Page 掘金主页 ...
- 微信小程序之快速接入七牛云
小程序为什么要接入云? 目前,开发者在开发小程序过程中,主要遇到以下几个问题: 小程序发布大小超限 微信官方限制小程序的发布代码不能超过 1MB,而在实际开发过程中,一般的小程序难免会有图片等富媒体文 ...
随机推荐
- MySQL——事务(Transaction)详解
原文:https://blog.csdn.net/w_linux/article/details/79666086
- 【JMeter_17】JMeter逻辑控制器__随机顺序控制器<Random Order Controller>
随机顺序控制器<Random Order Controller> 业务逻辑: 当控制器被触发时,将控制器下的所有子节点顺序打乱执行一遍,执行一遍,执行一遍,不是执行一个. 注意:是将子节点 ...
- 为什么Web开发人员在2020年不用最新的CSS功能
转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 原文出处:https://dzone.com/articles/why-masses-are-not-usi ...
- Java并发编程(05):悲观锁和乐观锁机制
本文源码:GitHub·点这里 || GitEE·点这里 一.资源和加锁 1.场景描述 多线程并发访问同一个资源问题,假如线程A获取变量之后修改变量值,线程C在此时也获取变量值并且修改,两个线程同时并 ...
- 为什么启动线程是start方法?
为什么启动线程是start方法 十年可见春去秋来,百年可证生老病死,千年可叹王朝更替,万年可见斗转星移. 凡人如果用一天的视野,去窥探百万年的天地,是否就如同井底之蛙? 背景:启动线程是start ...
- mysql大表在不停机的情况下增加字段该怎么处理
MySQL中给一张千万甚至更大量级的表添加字段一直是比较头疼的问题,遇到此情况通常该如果处理?本文通过常见的三种场景进行案例说明. 1. 环境准备 数据库版本: 5.7.25-28(Percona 分 ...
- Jmeter系列(29)- 详解 JDBC Connection Configuration
如果你想从头学习Jmeter,可以看看这个系列的文章哦 https://www.cnblogs.com/poloyy/category/1746599.html 前言 发起 jdbc 请求前,需要有 ...
- 新版MySQL开始使用时遇到的问题(时区、权限):
新版MySQL(本人Server version: 8.0.15)在刚开始使用时遇到的问题: 查看mysql安装版本:命令窗口 时区问题解决(The server time zone value 'Ö ...
- Dysregulation of Exosome Cargo by Mutant Tau Expressed in Human-induced Pluripotent Stem Cell (iPSC) Neurons Revealed by Proteomics Analyses(蛋白质组学揭示了人诱导的多能干细胞(iPSC)神经元中表达的突变Tau对外泌体的失调) 解读人:梁玉婷
期刊名:MCP 发表时间:(2020年4月) IF:4.828 单位:Skaggs School of Pharmacy and Pharmaceutical Sciences, University ...
- Spring — 循环依赖
读完这篇文章你将会收获到 Spring 循环依赖可以分为哪两种 Spring 如何解决 setter 循环依赖 Spring 为何是三级缓存 , 二级不行 ? Spring 为啥不能解决构造器循环依赖 ...