微信小程序引用npm包

一:首先在创建小程序项目自动生成的miniprogram中反键---->在终端中打开;

二:在打开的cmd窗口中输入命令 npm init 一直回车就行,构建package.json文件;

三:构建完package.json文件后,就可以尝试初始化项目,输入命令 npm install --production 

第一个问题解决方法是在刚刚初始化生成的package.json文件中增加一个属性,"private": true,

 

第二个和第三个问题是因为没有装工具包的文件,因此我们要在miniprogram的目录下面创建一个node_modules文件用来装工具包。

然后再次输入npm install --production 

四:以引用微信原生组件weui为测试 依旧是在miniprogram目录输入命令npm i weui-miniprogram

 

 

 然后在工具一栏中菜单栏中找到工具---->反键点击构建npm。等构建完成后我们会发现在miniprogram目录和node_modules目录中多了一个miniprogram_npm文件夹,这个就是我们要用到的一些组件。

五:新建一个文件夹mydemo以用表单验证为测试。

 

 

 在index.json中引入mp-form。

 

 

为了规范化,最好应该是在compoents中构建程序包...

这里可以看到我们已经引用进了mp-form ctrl+s没有报错,接下来试试验证功能。

在index.wxml插入以下代码用来验证用户姓名是否填写,如果没有填写,则给出提示。

<mp-toptips msg="{{error}}" type="error" show="{{error}}"></mp-toptips>
<view class="page__bd">
  <mp-form id="form" rules="{{rules}}" models="{{formData}}">
    <mp-cells title="用户基本信息">
      <mp-cell show-error prop="username" title="姓名" ext-class="">
        <input bindinput="formInputChange" data-field="username" class="weui-input" value="{{formData.username}}"></input>
      </mp-cell>
    </mp-cells>
  </mp-form>

  <view class="weui-btn-area">
    <button class="weui-btn" type="primary" bindtap="submitForm">确定</button>
  </view>
</view>

 

在index.js插入代码

Page({
  data: {
    formData:{
      username : '',
    },
    rules: [{
      name: 'username',
      rules: {
        required: true,
        message: '姓名必填'
      },
    }]
  },

  onLoad: function () {

  },

  formInputChange(e) {
    debugger
    const {field} = e.currentTarget.dataset
    this.setData({
        [`formData.${field}`]: e.detail.value
    })
},
  submitForm() {
    this.selectComponent('#form').validate((valid, errors) => {
      console.log('valid', valid, errors)
      if (!valid) {
        const firstError = Object.keys(errors)
        if (firstError.length) {
          this.setData({
            error: errors[firstError[0]].message
          })

        }
      } else {
        wx.showToast({
          title: '校验通过'
        })
      }
    })
  }


})

 

验证失败的截图:

 

 由此可见,weui组件已经通过npm方式给引用到项目里来了。

 

posted @ 2020-05-27 14:06  皮皮马y  阅读(1598)  评论(0编辑  收藏  举报