欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

微信小程序自定义组件之可清除的input组件

程序员文章站 2022-08-02 12:34:55
最近正在做的一个小程序项目中需要用到一个可清除的输入框控件,为了在项目中使用方便以及方便其他项目直接使用,便封装了一个可清除的input自定义组件。 组件需要达到的需求是...

最近正在做的一个小程序项目中需要用到一个可清除的输入框控件,为了在项目中使用方便以及方便其他项目直接使用,便封装了一个可清除的input自定义组件。

组件需要达到的需求是:输入框内没有内容时,删除按钮隐藏;当输入框内有内容时,删除按钮显示,点击删除按钮则清空输入框内所有内容。并且还可以设置输入框整体样式以及输入框左侧图标。

明确了需求之后,就可以开始着手实现了。

首先,在目标目录下新建一个自定义组件

微信小程序自定义组件之可清除的input组件

建好之后,我们需要来设计布局。根据需求来看,我们只需要三个组件:两个image和一个input。左边一个image提示图标,然后一个input输入框,最后一个image删除按钮。我们要把尽可能多的数据设置成可以修改的绑定数据,提高自定义组件的可扩展性。

最终确定的wxml布局文件如下:

<view class='input-class'>
   <image src='{{inputicon}}' mode="scaletofill" class='icon-class'></image>
   <input placeholder='{{inputhint}}' bindconfirm='{{confirmtap}}' style='flex:1;width:100%;padding-left:12rpx;' bindinput='inputlistener' bindconfirm='inputconfirm' value='{{inputvalue}}' type='{{inputtype}}' password='{{ispassword}}' confirm-type='{{confirmtype}}'></input>
   <image class="{{isclearshow?'clearimgshow':'clearimghide'}}" src='clear.png' bindtap='cleartap' mode='widthfix'></image>
</view>

然后,我们就要来设置组件的一些属性和监听方法了。小程序的组件属性列表是定义在.js文件的properties里的。把需要暴露出去并可以修改的属性都写在这里面。其语法示例如下:

properties: {
  myproperty: { // 属性名
   type: string, // 类型(必填),目前接受的类型包括:string, number, boolean, object, array, null(表示任意类型)
   value: '', // 属性初始值(可选),如果未指定则会根据类型选择一个
   observer: function(newval, oldval, changedpath) {
     // 属性被改变时执行的函数(可选),也可以写成在methods段中定义的方法名字符串, 如:'_propertychange'
     // 通常 newval 就是新设置的数据, oldval 是旧数据
   }
  },
  myproperty2: string // 简化的定义方式
 }

我的属性列表如下:

 /**
   * 组件的属性列表
   */
   properties: {
     inputhint: {
        type: string,
        value: '搜索'
     },
     inputicon: {
        type: string,
        value: 'search.png'
     },
     inputtype: {
        type: string,
        value: 'text'
     },
     ispassword: {
        type: boolean,
        value: false
     },
     confirmtype: {
        type: string,
        value: "done"
     }
   }

完成了属性列表的编写之后,接下来我们需要为自定义组件添加监听事件。

 事件系统是组件间通信的主要方式之一。自定义组件可以触发任意的事件,引用组件的页面可以监听这些事件。

监听以及触发事件的语法是这样的:

//触发事件
//自定义组件触发事件时,需要使用 triggerevent 方法,指定事件名、detail对象和事件选项
methods: {
  ontap: function(){
   var myeventdetail = {} // detail对象,提供给事件监听函数
   var myeventoption = {} // 触发事件的选项
   this.triggerevent('myevent', myeventdetail, myeventoption)
  }
 }
//监听事件
<!-- 当自定义组件触发“myevent”事件时,调用“onmyevent”方法 -->
<component-tag-name bindmyevent="onmyevent" />
<!-- 或者可以写成 -->
<component-tag-name bind:myevent="onmyevent" />

这里我们需要设置的触发事件有,输入框的输入事件以及输入框的确认事件。通过 triggerevent 方法指定事件名以及事件触发事件参数

 /**
   * 组件的方法列表
   */
   methods: {
     inputlistener: function (e) {
        var value = e.detail.value;
        var cursor = e.detail.cursor;
        if (value === null || value === undefined || value.length === 0) {
          this.setdata({
             isclearshow: false
          });
        } else {
          this.setdata({
             isclearshow: true
          });
        }
        var detail = {
          value: value,
          cursor: cursor
        };
        this.triggerevent('inputlistener', detail);
     },
     inputconfirm: function (e) {
        var value = e.detail.value;
        var detail = {
          value: value
        }
        this.triggerevent('inputconfirm', detail);
     },
     cleartap: function () {
        this.setdata({
          isclearshow: false,
          inputvalue: ''
        });
     }
   }

以上就已经完成了这个可清除input组件的自定义开发了。现在来看怎么使用这个组件。

首先在需要使用此组件的页面.json文件中设置usingcomponents属性来引入这个自定义组件

   "usingcomponents": {
     //这里是设置的组价标签名称以及组件地址
     "clearinput": "../../components/clearinput/clearinput"
   }

然后,我们就可以在页面中引用这个自定义组件了,引用的方式非常简单,通过我们在上一步设置的标签名称就可以引用了。

<clearinput inputhint='搜索订单' icon-class='common_search_img' input-class='common_search_input' confirmtype='search' bind:inputlistener='inputlistener' bind:inputconfirm='searchevent' />

最终实现的效果图如下:

微信小程序自定义组件之可清除的input组件

项目github地址:https://github.com/raomeng/templateofhotel

总结

以上所述是小编给大家介绍的微信小程序自定义组件之可清除的input组件,希望对大家有所帮助