wepy框架构建小程序(1)

基本操作:

# 安装脚手架工具
npm install wepy-cli -g # 创建一个新的项目
npm init standard myproject # 进入新项目文件夹和安装依赖
cd myproject && npm install # 跑项目
npm run dev

vscode 编辑器设置

在编辑器设置中设置:

{
// 小程序设置为false
"vetur.validation.template": false
}

由于编辑器的设置有分用户设置工作区设置用户设置就是全局的基本设置,由于上面的功能在Vue项目需要开启,所以上面的设置代码应该在工作区设置中设置

简单点说就是,用户设置是全局设置,而工作区设置就是当前打开的文件夹有效,也就是局部的设置。

定义事件(重点)

事件在web端是很重要的部分,这里要搞得清清楚楚。

事件分捕获阶段事件触发点冒泡阶段

我们用的最多的是冒泡阶段。原生小程序定义事件的方式是键值对的方式key:value

原生小程序的keys:

  • bind:冒泡阶段,对应web端的on
  • catch:用这个key来定义事件不会冒泡,相当于web端的event.stopPropagation()
  • capture-bind:这个key用来定义捕获阶段,不像web端,我们要兼容IE,只考虑冒泡,因为IE老版本没有捕获
  • capture-catch:这个key在触发事件后,终止捕获,由于是捕获 -> 触发事件 -> 冒泡,所以终止捕获也终止了冒泡

bindtap:在小程序中用tap替代click,移动端用tap是避免点击事件的300ms延时造成的bug,tap触发更快。

bind:tap:这个方式也可以,就是key:value方式定义事件,value就是事件名,其他事件名大多和web端一样

wepy的事件定义:

  • bindtap替换@tap
  • catchtap替换@tap.stop
  • capture-bind:tap替换@tap.capture
  • capture-catch:tap替换@tap.capture.stop

这些语法就是Vue的语法,就是要区分这个key:value,key是什么,value是什么

安装Sass

npm i wepy-compiler-sass --save-dev

然后在<style lang='scss'>

.wpy文件

  • <template>:对应.wxml
  • <script>:分成两部分。1、逻辑部分:除了config对象,其他对应.js文件;2、配置部分:即config对象,对应.json
  • <style>:对应.wxss
  • 注意:由于config对象对应.json,但是可以是原生js对象,最后会格式化成JSON

上面3个标签都支持srclang属性:

  • src:引入外联的文件,使用了这属性,内联的代码无效
  • lang:有多个值

各个标签的lang

  • style:默认值css、可能值css、less、scss、stylus、postcss
  • template:默认值wxml、可能值wxml、xml、pug
  • script:默认值babel、可能值babel、TypeScript

状态管理器: redux + wepy-redux

先用redux生成store

import { createStore, combineReducers, applyMiddleware } from 'redux'
import promiseMiddleware from 'redux-promise'
import * as reducers from './reducer' // 生成的store和React中的redux生成方法一模一样
const store = createStore(
combineReducers(reducers),
applyMiddleware(promiseMiddleware)
)

React注入store是通过<Provider>,而wepy-redux注入store的方法用setStore(store)

wepy有3中实例App实例Page实例Component实例App只能有一个,注入store就是要在app.wpy中注入

import { setStore } from 'wepy-redux'

// app.wyp
setStore(store)
  • setStore(store)要在wepy.app的页面注入

然后就可以在任何一个组件中使用:

  import { connect } from 'wepy-redux'

  @connect({
num(state) {
return state.counter.num
},
inc: 'inc'
}, {
addNum: INCREMENT,
asyncInc
})
  • connect(states, actions)
  • states:可以是数组Array或者对象Object,用法和VuexmapState一样
// states为数组,元素只能是字符串,和`vuex`的用法一样
@connect(['num', 'inc'])
  • actions:只能是对象Object,对象的value可以是字符串(action.type)或者函数

@connect(null, {
test: 'TEST',
test2: (...args) => ({ type: 'TEST', payload: args }),
test3: { type: 'TEST', payload: 1 }
}) // 对于value是字符串,`test(1)`相当于
dispatch({
type: 'TEST',
payload: 1
}) // 调用`test(1, 2)`相当于
dispatch({
type: 'TEST',
payload: [1, 2]
}) // 调用`tes2()`相当于
dispatch(val.apply(store, args)) // this 指向store 但是自定义的函数要返回符合 { type: 'TEST', payload }的`action`对象 // 调用`test3()`
dispatch({ type: 'TEST', payload: 1 })
  • 最主要的是dispatch还是redux的dispatch,搞成这样是想把dispatch搞成和vuex的dispatch一样使用,可以支持异步(redux中原本的dispatch是同步的)
  • 这里的dispatch是通过middleware修改了redux原生的dispatch,使用了redux-promise,这样dispatch就可以支持异步以及promise
  • wepy还使用了redux-actions,来实现mutationsactions。如果不喜欢这个可以自己换redux-thunk,都可以,这些内容都属于redux(异步action),有自己的实现方案就行,你甚至都不用也可以。
  • 关于actions,如果是异步的,用test2的方式,同步的直接一个type字符串或者一个action对象

页面生命周期钩子、组件生命周期钩子

  • onLoad
  • onShow
  • onReady
  • onHide
  • onUnload

其中组件和页面公用onLoadonShow

还要区分三大实例App实例Page实例Component实例

组件间通信

小程序的组件间通信和web端的组件是有分别的,小程序的组件,两者通信主要通过广播的方式。

  • $broadcast:事件是由父组件发起,所有子组件都会收到此广播事件,除非事件被手动取消
  • $emit:事件发起组件的所有祖先组件会依次接收到$emit事件
  • $invoke:是一个页面或者组件对另一个组件中的方法的直接调用

// 所有在当前页面或者组件中的组件,如果events定义了changeState事件,就会调用其回调函数,以及传入参数
this.$broadcast('changeState', arg1, arg2, ...) // 所有在当前组件的父组件或者父页面中,如果events定义了getId事件,就会调用其回调函数,以及 传入参数11
this.$emit('getId', 11) // 调用当前页面或者当前组件中的组件AddNumber的方法,方法add定义于methods中,以及传入参数2,相对于AddNumber.methods.add(2)
this.$invoke('AddNumber', 'add', 2)

wepy框架构建小程序(1)的更多相关文章

  1. wepy框架开发小程序遇到的node-sass问题解决方案

    一.报错图 二.解决方案 主要是windows平台缺少编译环境, 1.先运行: npm install -g node-gyp 2.然后运行cmd:(右键点击:以管理员身份运行) 输入:npm ins ...

  2. 使用wepy开发微信小程序商城第二篇:路由配置和页面结构

    使用wepy开发微信小程序商城 第二篇:路由配置和页面结构 前言: 最近公司在做一个微信小程序的项目,用的是类似于vue的wepy框架.我也借此机会学习和实践一下. 小程序官方文档:https://d ...

  3. 使用wepy开发微信小程序商城第三篇:购物车(布局篇)

    使用wepy开发微信小程序商城 第三篇:购物车(布局篇) 前两篇如下: 使用wepy开发微信小程序商城第一篇:项目初始化 使用wepy开发微信小程序商城第二篇:路由配置和页面结构 基于上两篇内容,开始 ...

  4. 使用wepy开发微信小程序商城第一篇:项目初始化

    使用wepy开发微信小程序商城 第一篇:项目初始化 前言: wepy小程序项目初始化的操作,官方文档看了好几遍,感觉写得不是很清楚. 这篇写得挺好的:小程序开发之wepy 1.初始化项目 (1)全局安 ...

  5. mpvue框架的小程序和H5同时开发

    demo链接1.样式统一为了达到共用一套样式,采用px2rem-loader和px2rpx-loader进行代码的打包,细节如下: 由于UI设计图是在蓝湖上标注,宽度750,选择像素 PX 样式中直接 ...

  6. mpvue构建小程序(步骤+地址)

    mpvue 是一个使用 Vue.js 开发小程序的前端框架(美团的开源项目).框架基于 Vue.js 核心,mpvue 修改了 Vue.js 的 runtime 和 compiler 实现,使其可以运 ...

  7. WePY 在手机充值小程序中的应用与实践

    wepyjs 发布了两个月了,中间经历了很多版本更新,也慢慢开始有一些用户选择 wepyjs 作为开发框架来开发小程序,比如一些线上小程序. 以及一些来自网上的 wepyjs 的相关资源: demo源 ...

  8. 基于 mpvue 框架的小程序选择控件,支持单列,多列,联动

    最近在学着写mpvue小程序,在做选择控件时候遇到了点问题,按照微信小程序方法picker,很不方便! 在网上搜到一个很好用的组件下面给大家分享: 组件说明文档链接:https://go.ctolib ...

  9. 使用wepy开发微信小程序01——常用的组件

    1.axio.js 'use strict' import axios from 'axios' import wepyAxiosAdapter from 'wepy-plugin-axios/dis ...

随机推荐

  1. 简单的方法爬取b站dnf视频封面步骤解释

    这随笔代码链接:http://www.cnblogs.com/yinghualuowu/p/8186375.html 首先我们要知道,一个分区封面显示到底在哪里可以找到. 很明显,查看审查元素并不能找 ...

  2. 1088 Rational Arithmetic(20 分)

    For two rational numbers, your task is to implement the basic arithmetics, that is, to calculate the ...

  3. Spring自动注入有关的注解

    Spring不但支持自己定义的@Autowired注解,还支持几个由JSR-250规范定义的注解,它们分别是@Resource.@PostConstruct以及@PreDestroy. 1,@Comp ...

  4. Toad for Oracle针对于Oracle数据库的可视化管理工具使用

    Toad for Oracle安装包下载地址:http://pan.baidu.com/s/1mgBOLZU 在Oracle应用程序的开发过程中,访问数据库对象和编写SQL程序是一件乏味且耗费时间的工 ...

  5. MongoDB Linux 安装配置 后台运行

    介绍安装的文档很多,可以参考这篇: http://www.mkyong.com/mongodb/how-to-install-mongodb-on-mac-os-x/ 安装完后你可能会碰到的2个问题. ...

  6. mysql服务器查询慢原因分析方法

    mysql数据库在查询的时候会出现查询结果很慢,超过1秒,项目中需要找出执行慢的sql进行优化,应该怎么找呢,mysql数据库提供了一个很好的方法,如下: mysql5.0以上的版本可以支持将执行比较 ...

  7. easyUI 实现异步tree

    html: <ul id="relInfoTree" class="easyui-tree"></ul> js: $(document) ...

  8. BZOJ3624: [Apio2008]免费道路(最小生成树)

    题意 题目链接 Sol 首先答案一定是一棵树 这棵树上有一些0边是必须要选的,我们先把他们找出来,如果数量$\geqslant k$显然无解 再考虑继续往里面加0的边,判断能否加到k条即可 具体做法是 ...

  9. Browser History

    History 对象中包含用户(在浏览器窗口中)访问过的URL History 对象是window对象的一部分,可通过window.history属性对其进行访问. 注释:没有应用于History对象 ...

  10. Vue.js(2.x)之Class 与 Style 绑定

    1.前面看数据绑定时还很困惑v-bind处理class时可以使用json格式的值,为什么换成id.href等其他属性就不行.看了下文档解释后明白了些: 2.对象语法主要有以下三种形式: 1)直接在v- ...