Vant组件库

1. 下载Vant Weapp

步骤一:通过 npm 安装

npm i @vant/weapp -S --production

步骤二:修改 app.json

将 app.json 中的 "style": "v2" 去除,小程序的新版基础组件强行加上了许多样式,难以覆盖,不关闭将造成部分组件样式混乱。

步骤三:修改 project.config.json

开发者工具创建的项目,miniprogramRoot 默认为 miniprogram,package.json 在其外部,npm 构建无法正常工作。

需要手动在 project.config.json 内添加如下配置,使开发者工具可以正确索引到 npm 依赖的位置。

"setting": {

 "packNpmManually": true,

"packNpmRelationList": [

{ "packageJsonPath": "./package.json",

"miniprogramNpmDistDir": "./miniprogram/" } ] 

}

注意: 由于目前新版开发者工具创建的小程序目录文件结构问题,npm构建的文件目录为miniprogram_npm,并且开发工具会默认在当前目录下创建miniprogram_npm的文件名,所以新版本的miniprogramNpmDistDir配置为'./'即可。

步骤四:构建 npm 包

点击工具-->构建npm

并勾选本地设置-->使用npm模块选项

在.json文件中配置使用的组件,可以在全局中配置,也可以在单独页面中配置。

"usingComponents": { "van-field": "@vant/weapp/field/index", "van-picker": "@vant/weapp/picker/index", "van-popup": "@vant/weapp/popup/index", "van-button": "@vant/weapp/button/index", "van-divider": "@vant/weapp/divider/index", "van-empty": "@vant/weapp/empty/index", "van-search": "@vant/weapp/search/index" }


2. 列表页添加搜索功能

 <!-- 导入wxs文件 -->

 <wxs src="../../wxs/filter.wxs" module="filter" /> 

 <view class="container">

<van-search model:value="{{ title }}" placeholder="请输入搜索关键词" bind:search="onSearch" bind:clear="onClear" />   

<navigator url="../vantdetails/vantdetails?id={{item.Id}}" class="data" wx:for="{{dataList}}" wx:key="index">

<view class="title">{{item.Title}}   </view>

<view class="flex j-s a-c desc">

<view>{{item.Section.Name}}</view>

<view>{{filter.formatTime(item.Createtime)}}</view>

</view> </navigator> </view>

<view bindtap="click" class="btn_add">+</view>

//搜索框的搜索方法 onSearch(){

this.data.pageIndex = 1 //页码重新设置为1

this.getDataList() //调用获取数据的方法

},

//搜索框的清空方法

onClear(){

//清空title

this.setData({

title:''

})

this.data.pagesIndex = 1 //页码重新设置为1

this.getDataList() //调用获取数据的方法

}


3. 重构添加页面


<view class="content">

  <view class="item">

    <van-field label="题目" title-width="80rpx"

    model:value="{{ title }}"

    placeholder="请输入题目" required />

  </view>

  <view class="item">

    <van-field label="答案" title-width="80rpx" type="textarea" autosize custom-style="height:150rpx"

    model:value="{{ answer }}"

    placeholder="请输入答案" required />

  </view>

  <view class="item">

    <van-field label="分类" title-width="80rpx" readonly

    model:value="{{ section_name }}"

    placeholder="请选择分类" bindtap="showPopup" required />

  </view>

  <view class="item">

    <van-field label="解析" title-width="80rpx" type="textarea" autosize custom-style="height:150rpx"

    model:value="{{ desc }}"

    placeholder="请输入答案" />

  </view>

  <view class="item flex j-c">

    <van-button loading="{{loading}}" loading-text="添加中..." type="primary" block round icon="plus" bindtap="click">添加题目</van-button>

  </view>

</view>

<van-popup position="bottom" show="{{ show }}" bind:close="onClose">

  <van-picker

  show-toolbar

  title="请选择分类" value-key="Name"

  columns="{{ typeList }}"

  bind:cancel="onClose"

  bind:confirm="onConfirm"

  />

</van-popup>

//获取分类信息的方法

async getTypeList(){

    let typeList = await wx.$get('/Section/GetSections')

    this.setData({

        typeList

    })

},

//显示弹出层方法

showPopup() {

    this.setData({ show: true });

},

//关闭弹出层方法

onClose() {

    this.setData({ show: false });

},

//选择器确定方法

onConfirm(event) {

    const { value } = event.detail;

    //设置分类编号和分类名称

    this.setData({

        section_id:value.Id,

        section_name:value.Name,

        show:false

    })

},

//添加按钮点击事件

async click(){

    //非空验证

    if(!this.data.title || !this.data.section_id || !this.data.answer)

        return wx.$msg('请输入完整信息!')

    //请求后台,添加题目信息

    this.setData({

        loading:true

    })

    let res = await wx.$post('/Subject/AddSubject',{

        title:this.data.title,

        answer:this.data.answer,

        desc:this.data.desc,

        section_id:this.data.section_id

    })

    if(res){

        wx.$msg('添加成功!')

        this.setData({

            loading:false

        })

        this.clear()  //清空数据

    }

},

//清空方法

clear(){

    this.setData({

        title:'',

        answer:'',

        desc:'',

        section_id:0,

        section_name:''

    })

}



4. 重构详情页

<view class="content" wx:if="{{data}}">

<view class="title">{{data.Title}}</view>

<van-divider fontSize="15" contentPosition="left" textColor="#248067" borderColor="#248067">答案</van-divider>

<view class="answer">{{data.Answer}}</view> <van-divider fontSize="15" contentPosition="left" textColor="#248067" borderColor="#248067">解析</van-divider>

<view class="desc">{{data.Desc}}</view>

</view>

<van-empty wx:else description="暂无数据" />

onLoad: function (options) {

if(Object.keys(options).length>0){ this.data.id = options.id

}

//调用获取数据的方法

this.getData()

},

//获取数据的方法

async getData(){

//根据题目的id,获取题目信息

let data = await wx.$get('/Subject/GetSubject',{id:this.data.id})

this.setData({ data })

},

onPullDownRefresh: function () {

//重新获取详情信息

//调用获取数据的方法

this.getData()

//1秒后关闭下拉刷新

setTimeout(() => { wx.stopPullDownRefresh()

}, 1000); }

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,718评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,683评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,207评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,755评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,862评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,050评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,136评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,882评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,330评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,651评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,789评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,477评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,135评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,864评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,099评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,598评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,697评论 2 351

推荐阅读更多精彩内容