zoukankan      html  css  js  c++  java
  • 小程序组件(六)

    picker组件的使用方法&&自定义构造函数的方法&&创建和使用对象的方法
    <!--index.wxml-->
    <view class="box">
      <view class='title'>个人信息填写</view>
      <view class='lineLayout'>
        <view>姓名:</view>
        <input placeholder='请输入姓名' bindinput="nameInput"></input>
      </view>
      <picker bindchange="pickerSex" range="{{gender}}">
        <view>性别:{{sex}}</view>
      </picker>
      <picker mode='region' bindchange='pickerRegion'>
        <view>籍贯:{{birthPlace}}</view>
      </picker>
      <picker mode="date" start="1800-01-01" end="2999-12-12" bindchange="pickerDate">
        <view>出生日期:{{birthDay}}</view>
      </picker>
      <view class='lineLayout'>
        <view>身高(CM):</view>
        <input type='number' bindinput="heightInput" placeholder='请输入身高'></input>
      </view>
      <view class='lineLayout'>
        <view>体重(KG):</view>
        <input type='digit' bindinput="weightInput" placeholder="请输入体重"></input>
      </view>
      <button type='primary' bindtap="showMessage">显示个人信息</button>
    
      <view hidden='{{flag}}'>
        <view>姓名:{{person.name}}</view>
        <view>性别:{{person.sex}}</view>
        <view>籍贯:{{person.birthPlace}}</view>
        <view>出生日期:{{person.birthDay}}</view>
        <view>身高(CM):{{person.height}}</view>
        <view>体重(KG):{{person.weight}}</view>
      </view>
    </view>
    class='lineLayout'实现一行显示
    mode='region'表示地区选择器,没有指定的话,默认是普通选择器
    /*index.wxss*/
    
    .lineLayout {
      display: flex;/*弹性布局*/
      flex-direction: row;/*行方向*/
      justify-content: flex-start; /*弹性盒子元素在主轴(横轴)方向上的对齐方式,左对齐*/
      align-items: center; /*定义flex子项在flex容器的当前行的侧轴(纵轴)方向上的对齐方式,居中*/
    }
    
    input {
      /* 设置input组件样式 */
      height: 30px;
      border-bottom: 2px solid silver;
      margin: 10rpx 0;
    }
    
    picker, button {
      /* 设置picker和button组件样式 */
      margin: 15px 0;
    }
     
    /*index.js*/
    
    function Person(name, sex, birthPlace, birthDay, height, weight) { //定义构造函数,用于创建对象
      this.name = name; //将函数参数赋值给对象属性
      this.sex = sex;
      this.birthPlace = birthPlace;
      this.birthDay = birthDay;
      this.height = height;
      this.weight = weight;
    }
    
    Page({
      data: { //初始数据
        flag: true, //个人信息显示标记,开始不显示
        gender: ["男", "女"]
      },
    
      nameInput: function(e) { //姓名input组件输入事件函数
        this.name = e.detail.value //获取input组件value值
      },
      pickerSex: function(e) { //性别picker组件事件函数
        this.sex = this.data.gender[e.detail.value] //获取性别
        this.setData({
          sex: this.sex //选择完成后在视图层picker组件后面显示性别
        })
      },
      pickerRegion: function(e) { //地区picker组件事件函数
        this.birthPlace = e.detail.value; //获取籍贯
        this.setData({
          birthPlace: this.birthPlace //选择完成后在视图层picker组件后面显示籍贯
        })
      },
      pickerDate: function(e) { //日期picker组件事件函数
        this.birthDay = e.detail.value //获取生日
        this.setData({
          birthDay: this.birthDay //选择完成后在视图层picker组件后面显示生日
        })
      },
      heightInput: function(e) { //身高input组件输入事件函数
        this.height = e.detail.value //获取身高
      },
      weightInput: function(e) { //体重input组件输入事件函数
        this.weight = e.detail.value //获取体重
      },
    
      showMessage: function(e) { //button组件事件函数   
        var p = new Person(this.name, this.sex, this.birthPlace, this.birthDay, this.height, this.weight) //利用构造函数创建对象
        this.setData({
          flag: false, //设置显示
          person: p //对象赋值
        })
      }
    })
    在一个文件当中,变量前面加了this,表明该变量是类的属性,那就可以通过this.属性名在本文件的其他地方进行引用
    this.sex = this.data.gender[e.detail.value]  普通选择器中选择的时候,e.detail.value传过来的是数组的下标,要显示值this.data.gender[e.detail.value]

    picker组件

      从屏幕底部弹起的滚动选择器,现支持五种类型的选择器,通过mode来区分,分别是:普通选择器、多列选择器、时间选择器、日期选择器和省市区选择器,默认的是普通选择器。

    普通选择器(mode = selector)和 多列选择器(mode = multiSelector)主要属性  

      

     时间选择器(mode = time)主要属性

      

    日期选择器(mode = date)主要属性 

      

    省市区选择器(mode = region)主要属性

      

    自定义构造函数

      也是一个普通函数,创建方式也和普通函数一样, 但构造函数习惯上首字母大写,如:

      function Person(name, sex) { //定义构造函数

        this.name = name; //将函数参数赋值给对象属性

        this.sex = sex;

      }

    创建和使用对象的方法

      创建对象通过new关键字,例如: var p = new Person(myName, mySex)  myName, mySex构造函数实参

      使用对象通过“.”来实现,例如:p.name

    picker选择器组件、自定义构造 函数的方法、利用自定义构造函数 创建对象实例和使用对象实例的方法。

  • 相关阅读:
    tf.placeholder函数说明
    网易雷火 游戏研发一面 5.7
    【python3】with的用法
    一分钟理解softmax函数(超简单)
    网易雷火 笔试 4.25
    cun
    HDU-2045-RPG上色(递推)
    HDU-2050-折线分割平面 (递推)
    POJ-2389-Bull Math(高精度乘法)
    HDU-1002-A + B Problem II(高精度加法)
  • 原文地址:https://www.cnblogs.com/suitcases/p/13439505.html
Copyright © 2011-2022 走看看