小程序-自定义组件

组件化开发已经是一个趋势了,其隔离,复用等的特性必定使得其运用越来越广,小程序也提供了自定义组件的功能,为了加深记忆,写一篇博文便于记忆

先看看最终效果
在这里插入图片描述
我这里自定义了一个弹窗:
接下来直接上步骤吧

1.新建component目录,以及commonDialog组件文件,上图最直观了

在这里插入图片描述

2.看看各个文件的内容

commonDialog.json文件
{
  "component": true,//表示这是一个组件
  "usingComponents": {}//如果当前组件有引用到其它组件,这里写组件的路径
}


commonDialog.wxml文件,这个文件就是组件的布局文件
 <view class='container'>
  <view class='content'>
    <text class='title'>{{dialogTitle}}</text>
    <text class='text'>{{dialogText}}</text>
    <view class='button_layout'>
      <button class='button_sure' type='primary' catchtap='_confirmEvent'>{{sureText}}</button>
      <button class='button_cancle' type='warn'>{{cancleText}}</button>
    </view>
  </view>
</view>

 commonDialog.js文件
 Component({
  /**
   * 组件的属性列表
   */
  properties: {
    dialogTitle:{
      type: String,
      value:'标题'
    },

    dialogText: {
      type: String,
      value: '标题'
    },

    sureText: {
      type: String,
      value: '标题'
    },

    cancleText: {
      type: String,
      value: '标题'
    }

  },

  /**
   * 组件的初始数据
   */
  data: {

  },

  /**
   * 组件的方法列表
   */
  methods: {
     _cancelEvent() {
      //触发取消回调
      this.triggerEvent("cancelEvent")
    },
  }
})

其中commonDialog.js ,commonDialog.wxml的属性对应关系如图
在这里插入图片描述

最后看commonDialog.wxss文件

.container{
  width: 100%;
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

.content{
  width: 100%;
  padding-bottom: 20rpx;
  padding-top: 20rpx;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.title{
  font-size: 50rpx;
  color: black;
}

.text{
  font-size: 40rpx;
  color: gray;
   margin-top: 20rpx;
}

.button_layout{
  width: 80vw;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  margin-top: 50rpx;
}

.button_sure{
  padding-left: 100rpx;
  padding-right: 100rpx;
 
}

.button_cancle{
  padding-left: 100rpx;
  padding-right: 100rpx;
}

好了,到此一个简单的组件制作完毕,还没有添加点击事件之类的,这个后面在补充

3.组件的使用

1.在需要使用组件的页面page.json文件里,配置组件的路径
在这里插入图片描述

2.直接在需要使用组件的 page.wxml中使用即可
在这里插入图片描述

3.那么点击事件怎么从组建传递到page呢

组建wxml如下图
在这里插入图片描述
组建的js文件内容如下
在这里插入图片描述
page页面的wxml如下图
在这里插入图片描述

page的js文件内容如下
在这里插入图片描述
好了,至此一个简单的组件就完成了

CommonDialog 控件 CommonDialog 控件提供一组标准的操作对话框,进行诸如打开和保存文件,设置打印选项,以及选择颜色和字体等操作。通过运行 Windows 帮助引擎控件还能显示帮助。 语法 CommonDialog 说明 CommonDialog 控件在 Visual Basic 和 Microsoft Windows 动态链接库 ommdlg.dll. 的例程之间提供了一个接口。为了用这个控件创建一个对话框,ommdlg.dll. 必须在 Microsoft Windows 的 SYSTEM 目录下。 在应用程序中要使用 CommonDialog 控件,可将其添加到窗体中并设置其属性。控件所显示的对话框由控件的方法确定。在运行时,当相应的方法被调用时,将显示一个对话框或是执行帮助引擎;在设计时,CommonDialog 控件是以图标的形式显示在窗体中。该图标的大小不能改变。 使用指定的方法,CommonDialog 控件能够显示下列对话。 方法 所显示的对话框 ShowOpen 显示“打开”对话框 ShowSave 显示“另存为”对话框 ShowColor 显示“颜色”对话框 ShowFont 显示“字体”对话框 ShowPrinter 显示“打印”或“打印选项”对话框 ShowHelp 调用 Windows 帮助引擎 在对话框接口上单击,CommonDialog 控件将自动提供与上下文有关的帮助: 单击标题栏中的“这是什么?”帮助按钮,然后单击想详细信息的项目。 将鼠标放在想进一步详细信息的项目上,单击右键,然后在所显示的上下文菜单中选择这是什么命令。 操作系统提供在 Windows 95 帮助弹出中显示的文本。也可以通过设置 Flags 属性,在带有 CommonDialog 控件的对话框中显示一个帮助按钮,但是,必须在这个位置提供帮助主题。 注意 无法指定对话框显示在什么地方。 详细信息 要查看各对话的帮助主题,单击“请参阅”。 下例显示“打开”对话框然后在信息框中显示所选的文件名: Private Sub Command1_Click() ' 设置“CancelError”为 True CommonDialog1.CancelError = True On Error GoTo ErrHandler ' 设置标志 CommonDialog1.Flags = cdlOFNHideReadOnly ' 设置过滤器 CommonDialog1.Filter = "All Files (*.*)|*.*|Text Files" & _ "(*.txt)|*.txt|Batch Files (*.bat)|*.bat" ' 指定缺省的过滤器 CommonDialog1.FilterIndex = 2 ' 显示“打开”对话框 CommonDialog1.ShowOpen ' 显示选定文件的名字 MsgBox CommonDialog1.filename Exit Sub ErrHandler: ' 用户按了“取消”按钮 Exit Sub End Sub 参考资料:MSDN var fd = new ActiveXObject("MSComDlg.CommonDialog"); fd.Filter = "Microsoft Office Word(*.doc)|*.doc"; fd.FilterIndex = 2; // 必须设置MaxFileSize. 否则出错 fd.MaxFileSize = 128; // fd.FileName=document.all.FlSubject.value+thisform.WFStartTime.value.split(" ")[0];; // 显示对话框 fd.ShowSave(); 判断"取消"事件,可判断fd.flags为0,或fd.FileName为空。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值