All Projects → blackjack0v0 → Mpvuesimple Quickstart

blackjack0v0 / Mpvuesimple Quickstart

mpvue的一个快速搭建脚手架,添加引入原生小程序开发的UI如iview-weapp、wux-weapp等,包含vuex、axios、mp-weui的示例

Programming Languages

javascript
184084 projects - #8 most used programming language

Labels

Projects that are alternatives of or similar to Mpvuesimple Quickstart

Mpvue Douban
基于 mpvue 实现豆瓣电影微信小程序 @zce
Stars: ✭ 288 (+305.63%)
Mutual labels:  mpvue
Ithome Lite
🥛 IT之家第三方小程序版客户端(使用 mpvue 开发,兼容 web)
Stars: ✭ 531 (+647.89%)
Mutual labels:  mpvue
Mpvue Xbyjshop
前端mpvue🚀后端nodejs🔋+thinkjs+mysql📂微信小程序商城
Stars: ✭ 973 (+1270.42%)
Mutual labels:  mpvue
Mpvue Zanui
使用 mpvue 框架重写 zanui。
Stars: ✭ 343 (+383.1%)
Mutual labels:  mpvue
Mpvue
基于 Vue.js 的小程序开发框架,从底层支持 Vue.js 语法和构建工具体系。
Stars: ✭ 20,383 (+28608.45%)
Mutual labels:  mpvue
Alaweb
一套 Vue 代码,多端可用(H5、小程序、苹果App、安卓App、头条等)。系统含150+页面,200+组件(5端通用),30+元件(每个终端独立完成)
Stars: ✭ 837 (+1078.87%)
Mutual labels:  mpvue
Vue Mpvue Chatrobot
㊙A chat robot for web & Wechat producted by vue+mpvue+nodejs.
Stars: ✭ 269 (+278.87%)
Mutual labels:  mpvue
Mpvue Loader
mpvue loader
Stars: ✭ 47 (-33.8%)
Mutual labels:  mpvue
Weapp.socket.io
A WebSocket client for building WeChat Mini Program implement by socket.io
Stars: ✭ 517 (+628.17%)
Mutual labels:  mpvue
Mpvue Animated Number
微信小程序 mpvue 数字更新滚动动画组件 / An animated number component for mpvue
Stars: ✭ 33 (-53.52%)
Mutual labels:  mpvue
Mpvue Entry
⛓️ 集中式页面配置,统一构建入口,支持新增页面热更新
Stars: ✭ 348 (+390.14%)
Mutual labels:  mpvue
Mpvue Cnode
用mpvue写的小程序版的cnode社区
Stars: ✭ 407 (+473.24%)
Mutual labels:  mpvue
Image Cropper
💯一款功能强大的微信小程序图片裁剪插件
Stars: ✭ 893 (+1157.75%)
Mutual labels:  mpvue
Mpvue Router Patch
🛴在 mpvue 中使用 vue-router 兼容的路由写法
Stars: ✭ 298 (+319.72%)
Mutual labels:  mpvue
Awesome Mpvue
A curated list of awesome things related to mpvue
Stars: ✭ 1,030 (+1350.7%)
Mutual labels:  mpvue
Mpvue Weui
基于 mpvue 的 weui 框架
Stars: ✭ 279 (+292.96%)
Mutual labels:  mpvue
Awesome Uni App
Awesome for uni-app! 基于Vue.js的跨平台多端应用前端框架uni-app一站式开发资源汇总
Stars: ✭ 689 (+870.42%)
Mutual labels:  mpvue
Mpvue Iview Weapp
使用mpvue导入iview-weapp
Stars: ✭ 61 (-14.08%)
Mutual labels:  mpvue
Vantweappmpvuedemo
mpvue中使用Vant Weapp
Stars: ✭ 46 (-35.21%)
Mutual labels:  mpvue
Uni App
uni-app 是使用 Vue 语法开发小程序、H5、App的统一框架
Stars: ✭ 34,949 (+49123.94%)
Mutual labels:  mpvue

mpvuesimple-quickstart

结合了@spencer1994mpvuecli@JJJYYmpvue-iview 两个项目

感谢@spencer1994告诉我mpvue本来就自带原生组件的引入功能!!现在把mpvue-entry重新加了回来。

在这里查看文档!

基本用法

$ npm install -g vue-cli
$ vue init blackjack0v0/mpvuesimple-quickstart  mpvuesimple
$ cd  mpvuesimple
$ cnpm install
$ git clone https://github.com/blackjack0v0/static 
$ cnpm run dev

引入原生组件用法

1.下载组件到根目录下static文件夹中,注意:本示例引入了一个wux.js文件在utils文件夹中, 如果你不用wux-weapp的话请手动删除,以免编译报错!!!

2.在src/router文件夹中的index.js为每个页面设置引入的组件

    config: {
      navigationBarTitleText: '首页',
      usingComponents: {
        'i-card': '../../static/iview/card/index'
        }

3.然后就可以直接在每个页面的index.vue组件中引用了

    <div>
      <i-card full title="卡片标题" extra="额外内容" thumb="https://i.loli.net/2017/08/21/599a521472424.jpg">
        <div slot="content">内容不错</div>
        <div slot="footer">尾部内容</div>
      </i-card>
    </div>

示例图片

示例的ask a question 使用了axios对api进行访问

注意

若原生组件通过click事件,即this.triggerEvent('click', { index })来进行父子组件通信,mpvue无法从event.mp中读取到正确的detail,原因是因为mpvue将click事件编译为tap导致this.triggerEvent('click', { index })无法找到click句柄

需要手动修改组件库中click事件名称,在这里修改iview文件中的modal/index.js文件:

this.triggerEvent('click', { index }) => this.triggerEvent('iclick', { index })

对应的模板中修改@click => @iclick

<i-modal title="删除确认" :visible="visible5" :actions="actions5" @iclick="handleClick5">
    <div>删除后无法恢复哦</div>
</i-modal>

在项目中 wux-weapp UI

示例图片2

步骤与前面相同,先下载组件到static文件夹

1.在src/router文件夹中的index.js需要用到的页面处引入

'usingComponents': {
'wux-floating-button': '/wux-weapp/dist/floating-button/index'
 }

2.在index.vue中使用

 <div><wux-floating-button v-bind:buttons="buttons" @iclick="handleClick6">
 </wux-floating-button>
 </div>

3.在方法中添加setdata的方法

 methods: {
    setData (data) {
      Object.keys(data).forEach(key => {
        this[key] = data[key]
      })
    }
   } 

到这里你就成功引入一个原生的小程序组件了!!!

组件具体参数的配置

查看wux的文档api发现 悬浮按钮一共有几个参数,如position属性、click事件

  • string、number属性---直接用position="topLeft"这种形式传递
  • array数组类的或者需要接受一个变量的---可以使用 v-bind:buttons="buttonsarray",这里buttons属性接受一个 buttonsarray数组,然后我们使用v-bind来把buttonsarray传递给buttons这个属性。
 data () {
    return {
      buttonsarray: [{
        label: '查看计数器',
        icon: "",
        url: '../counter/index'
      },
        { label: '查看logs',
          icon: "",
          url: '../logs/index'
        },
        { label: 'View on Demo',
          icon: "",
          url: '../counter/index'
        }
      ]
     }
   }
  • 事件类型的---使用@iclick="handleClick6"形式
<wux-floating-button position="topLeft" v-bind:buttons="buttons" @iclick="handleClick6">
 </wux-floating-button>
    handleClick6 (event) {
      const url = event.target.value.url
      console.log(event.target.value.url)
      wx.navigateTo({ url })
    },
  • 嵌套组件内各自事件的处理

这里我们的float-button展开后一共有3个按钮,我们可以通过event.target来获取点击事件的信息

查看float-button组件的源码中看到它已经把单个按钮的dataset赋值到value上了,所以我们通过 event.target.value来取得展开后每个按钮对应的数据,从而进行特定的处理

    handleClick6 (event) {
      const url = event.target.value.url
      console.log(event.target.value.url)
      wx.navigateTo({ url })
    },

下面为float-button原生组件的代码

index.wxml中

	<block wx:for="{{ buttons }}" wx:key="">
			<view class="wux-speed-dial__button {{ item.className }}" data-index="{{ index }}" data-value="{{ item }}" data-label="{{ item.label }}" catchtap="buttonClicked" hover-class="wux-speed-dial__button--hover">
				<image class="wux-speed-dial__icon" src="{{ item.icon }}" />
			</view>
		</block>

index.js中

       buttonClicked(e) {
            const { index, value } = e.currentTarget.dataset
            this.triggerEvent('iclick', { index, value })
            this.close()
        },

注意

这里修改了this.triggerEvent中的click为iclick

wux-weapp UI 复杂组件如gallery,toast组件的引入

示例图片3

  1. 把wux-weapp根目录下的index.js拷贝到src/utils文件夹中,并改名为wux.js(改名随意)

  2. 在页面router/index.js中引入组件

  3. 在index.vue导入wux.js以便使用已经写好的$wuxGallery函数,并使用组件

这些组件都需要通过先通过调用 getCurrentPages()获取页面示例, 然后使用selector选择器来选择组件节点,所以需要设置一个id,最终通过$wuxGallery(id)函数来获取节点的实例

<script>
import { formatTime } from '@/utils/index'
import card from '@/components/card'
import { $wuxGallery } from '@/utils/wux'
export default {....}
</script>
  <wux-gallery id="wux-gallery"></wux-gallery>
    <div v-for=" (url,index) in urls " >
       <img  :src="url"  @click="showGallery(index)" />
    </div>

3.1配置好要显示的图片urls

 data(){
    return {
        urls: [
        'https://unsplash.it/200/200',
        'https://unsplash.it/300/300',
        'https://unsplash.it/400/400',
        'https://unsplash.it/600/600',
        'https://unsplash.it/800/800',
        'https://unsplash.it/900/900',
        'https://unsplash.it/1000/1000',
        'https://unsplash.it/1200/1200',
       ]
      }
     }

3.2在方法中添加setdata的方法

 methods: {
    setData (data) {
      Object.keys(data).forEach(key => {
        this[key] = data[key]
      })
    }
   } 

4.写showGallery(url,index)函数

注意:不用自己写,对着wux-weapp的文档示例修改即可,我们具体内部函数this.$wuxGallery.show 不用修改,只要修改传入的参数,这里this.$wuxGallery.show需要urls列表及当前显示的目标current这两个值。

    <div v-for=" (url,index) in urls " >
       <img  :src="url"  @click="showGallery(index)" />
    showGallery(current) {
      const urls=this.urls
      this.$wuxGallery = $wuxGallery()
      this.$wuxGallery.show({
        current,
        urls,
        [`delete`]: (current, urls) => {
          urls.splice(current, 1)
          this.setData({
            urls,
          })
          return true
        },
        cancel() {
          console.log('Close gallery')
        },
        onTap(current, urls) {
          console.log(current, urls)
          return true
        },
        onChange(e) {
          console.log(e)
        }
      })
    }

下面是官网文档示例的函数

    showGallery(e) {
       /* const { current } = e.currentTarget.dataset
        const { urls } = this.data     */ 这里被修改的部分

        this.$wuxGallery = $wuxGallery()     

        this.$wuxGallery.show({
         ...内容同前
        })
    }

用vue写处理函数传值一对比明显更加简便了....

其他更多详细文档请查阅mpvue-iview

其他加强功能的说明

自动注册store

优点:多人协作开发不需要担心代码冲突,不需要每个store.js都要import引入。

使用flyio并封装了请求,

优点:根据vuex官方推荐,将background API封装到actions中,具体用法可在代码里查看。

其他更多详细文档请查阅mpvue-cli

踩坑注意

如果你初始化一个项目后又想改项目的名字,这个时候你运行cnpm run dev 的时候会发现

Error: Cannot find module '***',这个时候你需要删除node_module文件夹, 然后再运行cnpm install!!

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].