第四章页面组件总结

4.1组件的定义及属性

组 件是 页 面 视图层 (WXML) 的基本 组 成 单 元, 组 件 组 合可以构建功能 强 大的 页 面 结 构。 小程 序框架 为 开 发 者提供了容器 视图 、 基 础 内容、 表 单 、 导 航、 多媒体、 地 图 、 画布、 开放能力 等 8 类 (30 多个 ) 基 础组 件。 每一个 组 件都由一 对标签组 成, 有开始 标签 和 结 束 标签 , 内容放置在开始 标签 和 结 束 标签 之 间 , 内容也可以是 组 件。 组 件的 语 法格式如下: < 标签 名属性名 =” 属性 值 ”> 内容 …</ 标签 名 > 组 件通 过 属性来 进 一步 细 化。 不同的 组 件可以有不同的属性, 但它 们 也有一些共用属性, 如 id 、 class 、 style 、 hidden 、 data-* 、 bind*/catch* 等。

■id 组 件的唯一表示, 保持整个 页 面唯一, 不常用。

■class 组 件的 样 式 类 , 对应 WXSS 中定 义 的 样 式。

■style 组 件的内 联样 式, 可以 动态设 置内 联样 式。

■hidden 组 件是否 显 示, 所有 组 件默 认显 示。

■data-* 自定 义 属性, 组 件触 发 事件 时 , 会 发 送 给 事件 处 理函数。 事件 处 理函数可以通 过传 人 参数 对 象的 currentTarget. dataset 方式来 获 取自定 义 属性的 值 。

■ bind*/catch* 组 件的事件, 绑 定 逻辑层 相关事件 处 理函数。

4.2容器视图组件

 容器视图组件是能容纳其他组件的组件,是构建小程序页面布局的基础组件,主要包括 view 、 scroll-view 和 swiper组件

4.2.1view

view 组 件是 块级组 件, 没有特殊功能, 主要用于布局展示, 相当于 HTML 中的 div, 是布局 中最基本的用 户 界面 (UserInterface,UI) 组 件, 通 过设 置 view 的 CSS 属性可以 实现 各种复 杂 的布局。 view 组 件的特有属性如表  所示。

 通过<view>组件实现页面布局示例代码如下:

<!--pages/zujian/zujian.wxml-->
<view style="text-align: center">默认flex布局</view>
<view style="display: flex">
<view style="border:1px solid #f00;flex-grow:1">1</view>
<view style="border:1px solid #f00;flex-grow:1">2</view>
<view style="border:1px solid #f00;flex-grow:1">3</view>
</view>
<view style="text-align:center">上下混合布局</view>
<view style="display: flex;flex-direction:column">
<view style="border: 1px solid #f00;">1</view>
<view style="display: flex">
<view style="border: 1px solid #f00;flex-grow: 1">
</view>
<view style="border:1px solid #f00;flex-grow: 2">
</view>
</view>
</view>
<view style="text-align: center">左右混合布局</view>
<view style="display: flex">
<view style="border:1px solid #f00; flex-grow:1"></view>
<view style="display: flex;flex-direction: column;flex-grow: 1;">
<view style="border: 1px solid #f00;flex-grow: 1">2</view>
<view style="border: 1px solid #f00;flex-grow: 2"></view>
</view>
</view>

 运行效果如图:

4.2.2scrow-view 
通过设置scroll-view组件的相关属性可以实现滚动视图的功能,其属性如表所示。  

 

【注意】
(1)在使用竖向滚动时,如果需要给scroll-view组件设置一个固定高度,可以通过WXSS设置 height来完成。
(2)请勿在scroll-view组件中使用textarea、map、canvas、video组件。
(3)scroll -into -view 属性的优先级高于 scroll -top。
(4)由于在使用scroll-view组件时会阻止页面回弹,所以在 scroll-view组件滚动时无法触发onPullDownRefresh。
(5)如果要实现页面下拉刷新,请使用页面的滚动,而不是设置scroll-view组件。这样做,能通过单击顶部状态栏回到页面顶部。
通过scroll-view组件可以实现下拉刷新和上拉加载更多,代码如下: 

//scroll-view.wxml
<view class="container" style="padding:0 rpx">
<!--垂直滚动,这里必须设置高度-->
<scroll-view scroll-top="{{scrollTop}}" scroll-y="true"
style="height: {{scrollHeight}} px;"class="list" bindscrolltolower="bindDownLoad"
bindscrolltoupper="topLoad"bindscroll="scroll">
<view class="item"wx:for="{{list}}">
<image class="img"src="{{item.pic_url}}"></image>
<view class="text">
<text class="title">{{item.name}}</text>
<text class="description">{{item.short_description}}</text>
</view>
</view>
</scroll-view>
<view class="body-view">
<loading hidden="{{hidden}}"bindchange="loadingChange">
加载中....
</loading>
</view>
</view>
//scroll-view.js
// pages/zujian/zujian.ts

var url ="http://www.imooc.com/course/ajaxlist";
var page = 0;
var page_size  =5;
var sort ="last";
var is_easy = 0;
var lange_id = 0;
var pos_id = 0;
var unlearn = 0;
 //请求数据
 var loadMore=function(that){
  that.setData({
    hidden:false
  });
  wx.request({
    url: 'url',
    data:{
      page:page,
      page_size:page_size,
      sort:sort,
      is_easy:is_easy,
      lange_id:lange_id,
      pos_id:pos_id,
      unlearn:unlearn
    },
    success:function(res){
      //console.info(that.data.list)
      var list=that.data.list;
      for(var i=0;i<res.data.list.length;i++){
        list.push(res.data.list[i]);
      }
      that.setData({
        list:list
      });
      page++;
      that.setData({
        hidden:true
      });
    }
  });
}
Page({
  data:{
    hidden:true,
    list:[],
    scrollTop:0,
    scrollHeight:0
  },
  onLoad:function(){
    //这里要注意,微信的scroll-view必须设置高度才能监听滚动事件,所以需要在页面的onLoad事件中为scroll-view的高度赋值
    var that=this;
    wx.getSystemInfo({
      success:function(res){
        that.setData({
          scrollHeight:res.windowHeight
        });
      }
    });
    loadMore(that);
  },
  //页面滑动到底部
  binDownLoad:function(){
    var that=this;
    loadMore(that);
    console.log("lower");
  },
  scroll:function(event){
    //该方法绑定了页面滚动时的事件,这里记录了当前的position.y的值,为了在请求数据后把页面定位到这里
    this.setData({
      scrollTop:event.detail.scrollTop
    });
  },
  topLoad:function(event){
    //该方法绑定了页面滑动到顶部的事件,然后做页面上拉刷新
    page=0;
    this.setData({
      list:[],
      scrollTop:0
    });
    loadMore(this);
    console.log("lower");
  }
})



//scroll-view.wxss
/* pages/zujian/zujian.wxss */
.userinfo{
  display: flex;
  flex-direction: column;
  align-items: center;
}
.userinfo-avatar{
  width: 128rpx;
  height: 128rpx;
  margin: 20rpx;
  border-radius: 50%;
}
.userinfo-nickname{
  color: #aaa;
}
.usermotto{
  margin-top:200px;
}
/**/
scroll-view{
  width: 100%;
}
.item{
  width: 90%;
  height: 300px;
  margin: 20rpxauto;
  background: brown;
  overflow: hidden;
}
.item.img{
  width: 430px;
  margin-right: 20rpx;
  float: left;
}
.title{
  font-size: 30rpx;
  display: block;
  margin: 30rpxauto;
}
.description{
  font-size: 26px;
  line-height:15rpx;
}

4.2.3 swiper 

swipg组件可以实现轮播图、图片预览、滑动页面等效果。一个完整的swiper组件由
<swipa/>和<swiper-icmv>两个标签组成、它们不能单独使用。<swipe/>中只能放置个或多个<swipe-iem/>、若放置其他组件则会被删除;<swiper_nem/>内部可以藏置任何组件,默认宽高自动设置为100%。swiper组件的属性如表所示

<swipex-iem/>组件为滑块项组件,仅可以被放置在<swipe/>组件中,宽高尺寸默镇按100%聂示
设置*wie组件,可以实现轮播图效果,代码如下: 


<swiper indicator-dots='true' autoplay='true' interval='5000' duration='1000'>
<swiper-item>
<image src="/images/j4.jpg" style="width: 100%"></image>
</swiper-item>
<swiper-item>
<image src="/images/j6.jpg" style="width: 100%"></image>
</swiper-item>
<swiper-item>
<image src="/images/j7.jpg" style="width: 100%"></image>
</swiper-item>
</swiper>

 运行效果如下:

4.3基础内容组件

基础内容组件包括icon、text和progress,主要用于在视图页面中展示图标、文本和进度条等信息

4.3.1 icon

icon组件即图标组件,通常用于表示一种状态,如sueces、imo、wam、waing、amd等。其属性如表所示

//wxml

<view>icon类型:
<block wx:for="{{iconType}}">
<icon type="{{item}}"/>{{item}}
</block>
</view>
<view>icon 大小:
<block wx:for="{{iconSizs}}">
<icon type="success" size="{{item}}"/>{{item}}
</block>
</view>
<view>icon 颜色:
<block wx:for="{{iconColor}}">
<icon type="success" size="30" color="{{item}}"/>{{item}}
</block>
</view>


//js
Page({
    data:{
      iconType:["success","success_no_circle","info","warn","waiting","cancel","download","search","clear"],
      iconSize:[10,20,30,40],
      iconColor:['#f00','#0f0','#00f','#000','#ff0']
    }
  })



运行效果下: 

4.3.2 text

text 组件用于展示内容,类似HTML中的<span>.tex 组件中的内容支持长按选中,支持转义字符“\”,属于行内元素。lex组件的属性如表所示。


//wxml

<block wx:for="{{x}}" wx:for-item="x">
<view class="aa">
<block wx:for="{{25-x}}" wx:for-item="x">
<text decode="{{true}}" spaace="{{true}}">&nbsp;</text>
</block>
<block wx:for="{{y}}" wx:for-item="y">
<block wx:if="{{y<=2*x-1}}">
<text>*</text>
</block>
</block>
</view>
</block>
<block wx:for="{{x}}" wx:for-item="x">
<view class="aa">
<block wx:for="{{19+x}}" wx:for-item="x">
<text decode="{{true}}" spaace="{{true}}">&nbsp;</text>
</block>
<block wx:for="{{y}}" wx:for-item="y">
<block wx:if="{{y<=11-2*x}}">
<text>*</text>
</block>
</block>
</view>
</block>
//js
Page({
    data:{
      x:[1,2,3,4,5],
      y:[1,2,3,4,5,6,7,8,9]
    }
  })
  



运行效果如下: 

 4.3.3progress

progress组件用于显示进度状态,如资源加载、用户资料完成度、媒体资源播放进度等progress组件属于块级元素,其属性如表所示

示例代码如下: 

<view>显示百分比 </view>
<progress percent='80'show-info='80'></progress>
<view>改变宽度</view>
<progress percent='50'stroke-width='2'></progress>
<view>自动显示进度条</view>
<progress percent ='80'active></progress>

运行效果如下: 

 4.4表单组件

表单组件的主要功能是收集用户信息,并将这些信息传递给后台服务器,实现小程序用户之间的沟通。表单组件不仅可以放置在<form/>标签中使用,还可以作为单独组件和其他组件混合使用。

4.4.1button

button 组件用来实现用户和应用之间的交互,同时按钮的颜色起引导作用。,一般来说在一个程序中一个按钮至少有3种状态:默认点击(deault)、建议点击(primary)、谨慎点击(warn)。在构建项目时,应在合适的场景使用合适的按钮,当<button>被<form/>包裹时,可以通过设置form-type属性来触发表单对应的事件。buton组件的属性如表所示

示例代码如下: 

//wxml
<button type="default">type:default</button>
<button type="primary">type:primary</button>
<button type="warn">type:warn</button>
<button type="default" bindtap='buttonSize' size="{{size}}">改变size</button>
<button type="default" bindtap='buttonPlain'plain="{{plain}}">改变plain</button>
<button type="default" bindtap='buttonLoading' loading="{{loading}}">改变loading显示</button>
//js
  page({
    data:{
      size:'default',
      plain:'false',
      loading:'false'
    },
    //改变按钮大小
    buttonSize:function(){
      if(this.data.size=="default")
      this.setData({size:'mini'})
      else
      this.setData({size:'default'})
    },
    //是否显示缕空
    buttonPlain:function(){
this.setData({plain:! this.data.plain})
    },
    //是否显示loading图案
    buttonLoading:function(){
this.setData({loading:! this.data.loading})
    }
    })

4.4.2radio 

单选框用来从一组选项中选取一个选项在小程序中,单选框由<radio-group/>(单项选择器)和<radio/>(单选项目)两个组件组合而成,一个包含多个<radio/>的<edio-group/>表示一组单选项,在同一组单选项中<radio/>是互斥的,当一个按钮被避中后,之前选中的按钮就变为非选。它们的属性如表所示,

实例代码如下:

//wxml
<view>选择你喜欢的城市:</view>
<radio-group bindchange="citychange">
<radio value="西安">西安</radio>
<radio value="北京">北京</radio>
<radio value="上海">上海</radio>
<radio value="广州">广州</radio>
<radio value="江西">江西</radio>
</radio-group>
<view>你的选择:{{city}}</view>
<view>选择你喜爱的计算机语言:</view>
<radio-group class="radio-group" bindchange="radiochange">
<label class="radio" wx:for="{{radios}}">
<radio value="{{item.value}}" checked="{{item.checked}}"/>
{{item.name}}
</label>
</radio-group>
<view>你的选择:{{lang}}</view>
//js
page({
  data:{
    radios:[
      {name:'java',value:'JAVA'},
      {name:'python',value:'Python',checked:'true'},
     {name:'php',value:'PHP'},
     {name:'swif',value:'Swif'},
    ],
    city:"",
    lang:""
  },
  citychange:function(e){
    this.setData({city:e.detail.value});
  },
  radioschange:function(event){
    this.setData({lang:event.detail.value});
    console.log(event.detail.value)
  }
})
  
  


 运行效果如下:

4.4.3checkbox 

复选框用手从一组选项中选取多个选项,小中复选框由<checkbox-group/>(多项选释器)和<eeckhox/>(多选项目)两个组件而成,一个<echeckbox-group>表示一组选项,可以在一维选项中,所属性如表所是

 示例代码如下:

//wxml
<view>选择你想去的城市:</view>
<checkbox-group bindchange="cityChange">
<label wx:for="{{citys}}">
<checkbox value="{{item.value}}" checked='{{item.checked}}'>
{{item.value}}
</checkbox>
</label>
</checkbox-group>
<view>你的选择是{{city}}</view>
//js
Page({
  city:'',
    data:{
     citys:[
    {name:'km',value:'昆明'},
    {name:'sy',value:'三亚'},
    {name:'zh',value:'珠海',checked:'true'},
    {name:'dl',value:'大连'}]
    },
  cityChange:function(e){
    console.log(e.detail.value);
    var city=e.detail.value;
    this.setData({city:city})
  }
  })

page({
  data:{
    radios:[
      {name:'java',value:'JAVA'},
      {name:'python',value:'Python',checked:'true'},
     {name:'php',value:'PHP'},
     {name:'swif',value:'Swif'},
    ],
    city:"",
    lang:""
  },
  citychange:function(e){
    this.setData({city:e.detail.value});
  },
  radioschange:function(event){
    this.setData({lang:event.detail.value});
    console.log(event.detail.value)
  }
})
  
  


 示例代码如下:

4.4.4switch
switch组件的有用类但开关选择器,其属性如表所示:

 示例代码如下:

//wxml
<view>
<switch bindchange="sw1">{{var1}}</switch></view>
<view>
<switch checked bindchange="sw2">{{var2}}</switch>
</view>
<view>
<switch type="checkbox" bindchange="sw3">{{var3}}</switch>
</view>
//js
Page({
  
    data:{
    var1:'关',
   var2:'开',
   var3:'未选'
  },
  sw1:function(e){
    this.setData({var1:e.detail.value?'开':'关'})
  },
  sw2:function(e){
    this.setData({var2:e.detail.value?'开':'关'})
  },
  sw3:function(e){
    this.setData({var3:e.detail.value?'已选':'未选'})
  }
})

 运行效果如下:

4.4 .5slider

slider组件为滑动选择器,可以通过滑动来设置相应的值,其属性如表所示

 示例代码如下:

//wxml
<view>默认min=0 max=100 step=1</view>
<slider></slider>
<view>显示当前值</view>
<slider show-value></slider>
<view>设置min=20 max=200 step=10</view>
<slider min='0' max='200' step='10' show-value></slider>
<view>背景条红色,已选定颜色绿色</view>
<slider color="#f00" selected-color='#0f0'></slider>
<view>滑动改变icon的大小</view>
<slider show-value bindchange='sliderchange'></slider>
<icon type="success" size='{{size}}'></icon>
//js
Page({
  
    data:{
  size:'20'
  },
  sliderchange:function(e){
    this.setData({size:e.detail.value})
  }
})
  
  


 运行效果如下:

4.4.6picker 

picker组件为滚动选择器,当用户点击picker组件时,系统从底部弹出选择器供用户选择。picker组件目前支持5种选择器,分别是:selector(普通选择器)、multiSelector(多列选择器)、time(时间选择器)、date(日期选择器)、region(省市选择器)。

1,普通选择器
普通选择器(mode=selector)的属性如表所示

示例代码如下:

//wxml
<view>--------range为数组</view>
<picker range="{{array}}" value="{{index1}}" bindchange='arrayChange'>
当前选择:{{array[index1]}}
</picker>
<view>---range为数组对象</view>
<picker
bindchange="objArrayChange" value="{{index2}}" range-key="name" range="{{objArray}}">
当前选择:{{array[index2].name}}
</picker>
//js
Page({
  
    data:{
 array:['Java','Python','C','C#'],
 objArray:[
   {id:0,name:'Java'},
   {id:0,name:'Python'},
   {id:0,name:'C'},
   {id:0,name:'C#'}
 ],
 index1:0,
 index2:0
  },
  arrayChange:function(e){
    console.log('picker值变为',e.detail.value)
    var index=0;
    this.setData({
      index1:e.detail.value
    })
  },
  objArrayChange:function(e){
    console.log('picker值变为',e.detail.value)
    this.setData({
      index2:e.detail.value
    })
  }
})
  
  


 运行效果如下:

2.多列选择器 

多列选择器(mode=multiSelector)允许用户从不同列中选择不同的选择项,其选项是二维数组或数组对象。多列选择器的属性如表所示

//wxml
<view>多列选择器</view>
<picker rmode="multiSelector" bindchange="bindMultiPicker-Change" bindcolumnchange="bindMultPickerColumnChange"
value="{{multiIndex}}"
range="{{multiArray}}">
<view>
当前选择:{{multiArray[0][multiIndex[0]]}},{{multiArray[1][multiIndex[1]]}},{{multiArray[2][multiIndex[2]]}}
</view>
</picker>
//js
Page({
  
    data:{
 multiArray:[['江西省','广东省'],['西安市','汉中市','延安市'],['雁塔区','长安区']],
 multiIndex:[0,0,0]
  },
  bindMultiPickerChange:function(e){
    console.log('picker 发送选择改变,携带值为',e.detail.value)
    this.setData({
      multiIndex:e.detail.value
    })
  },
  bindMultiPickerColumnChange:function(e){
    console.log('修改的列为',e.detail.column,',值为',e.detail.value);
    var data = {
      multiArray:this.data.multiArray,
      multiIndex:this.data.multiIndex
    };
    data.multiIndex[e.detail.column]=e.detail.value;
    switch(e.detail.column){
  case 0:
switch(data.multiIndex[0]){
  case 0:
  data.multiArray[1]=['西安市','汉中市','延安市'];
  data.multiArray[2]=['雁塔市','长安区'];
  break;
  case 1:
  data.multiArray[1]=['深圳市','珠海市'];
  data.multiArray[2]=['南山区','罗湖区'];
  break;
}
data.multiIndex[1] = 0;
data.multiIndex[2] =  0;
break;
case 1:
  switch(data.multiIndex[0]){
    case 0:
    switch(data.multiIndex[1]){
      case 0:
        data.multiArray[2]=['雁塔区','长安区'];
        break;
        case 1:
        data.multiArray[2]=['汉台区','南郑区'];
        break;
        case 2:
        data.multiArray[2]=['子塔区','子长县','延长县'];
        break;
    }
    break;
        case 1:
switch(data.multiIndex[1]){
  case 0:
    data.multiArray[2]=['南山区','罗湖区'];
    break;
    case 1:
      data.multiArray[2]=['香洲区','斗门区'];
}
      break;
}
data.multiIndex[2]=0;
console.log(data.multiIndex);
break;
    }
    this.setData(data);
  },
})
  
  


 运行效果如下:

 示例代码如下:

//wxml
<view>
<picker mode="date" start="{{startdate}}" end="{{enddate}}" value="{{date}}" bindchange="changedate">
选择的日期:{{date}}
</picker>
</view>
<view>
<picker mode="time" start="{{starttime}}" end="{{endtime}}" bindchange="changetime">
选择你的时间:{{time}}
</picker>
</view>
//js
Page({
  
    data:{
    startdate:2000,
    enddate:2050,
    date:'2018',
    starttime:'00:00',
endtime:'12:59',
time:'8:00'
  },
  changedate:function(e){
    this.setData({date:e.datail.value});
    console.log(e.detail.value)
  }
})
  
  


运行效果如下: 

 

 示例代码如下:

//wxml
<picker mode="region" value="{{region}}" custom-item="{{cust-omitem}}" bindchange="changeregion">
选择省市区:{{region[0]}},{{region[1]}},{{region[2]}}
</picker>
//js
Page({
  
    data:{
   region:['陕西省','西安市','长安区'],
   customitem:'全部'
  },
  changeregion:function(e){
    console.log(e.detail.value)
    this.setData({
      region:e.detail.value
    })
  }
})
  
  


 运行效果如下:

4.4.7 picker-view 

 picker-view组件为嵌人页面的滚动选择器。相对于pieker组件,picker-view组件的列的个数和列的内容由用户通过<picker-viewcolumn/>自定义设置。picker-view组件的属性如表所示。

picker-view 组件属性

 示例代码如下:

//wxml
<view>当前日期:{{year}}年{{month}}月{{day}}日</view>
<picker-view indicator-style="height:50px;" style="width: 100%;;height: 300px;" value="{{value}}" bindchange="bindChange">
<picker-view-column>
<view wx:for="{{year}}" style="line-height: 50px;">{{item}}年</view>
</picker-view-column>
<picker-view-column>
<view wx:for="{{months}}" style="line-height: 50px;">{{item}}年</view>
</picker-view-column>
<picker-view-column>
<view wx:for="{{days}}" style="line-height: 50px;">{{item}}年</view>
</picker-view-column>
</picker-view>
//js
const date=new Date()
const years=[]
const months=[]
const days=[]
for(let i=1900;i<=2050;i++){
  years.push(i)
}
for(let i=1;i<=12;i++){
  months.push(i)
}
for(let i=1;i<=31;i++){
  days.push(i)
}
Page({
  data:{
    years:years,
    months:months,
    days:days,
    year:date.getFullYear(),
    month:date.getMonth()+1,
    day:date.getDate(),
    value:[2018,0,0],
  },
  bindChange:function(e){
    const val=e.detail.value
    console.log(val);
    this.setData({
      year:this.data.years[val[0]],
      month:this.data.month[1],
      day:this.data.days[2]
    })
  }
 })

 运行效果下:

4.4.8 input 

imnpu 组件为输人框,用户可以输人相应的信息,其属性如表所示

input组件属性

 

 示例代码如下:

//wxml
<input placeholder="这是一个可以自动聚焦的input" auto-focus/>
<input placeholder="这个只有在按钮点击的时候才聚焦" focus= "{{focus}}"/>
<button bindtap="bindButtonTap">使得输入框获取焦点</button>
<input maxlength="10" placeholder="最大输入长度为10"/>
<view class="section_title">你输入的是:{{inputValue}}</view>
<input bindinput="bindKeyInput" placeholder="输入同步到view中"/>
<input bindinput="bindReplaceInput" placeholder="连续的两个1会变成2"/>
<input password type="number"/>
<input password type="text"/>
<input type="digit" placeholder="带小数点的数字键盘"/>
<input type="idcard" placeholder="身份证输入键盘"/>
<input placeholder-style="color:red" placeholder="占位符字体是红色的"/>
//js
Page({
  data:{
    focus:false,
    inputValue:""
  },
  bindButtonTap:function(){
    this.setData({
      focus:true
    })
  },
  bindKeyInput:function(e){
    this.setData({
      inputValue:e.detail.value
    })
  },
  bindReplaceInput:function(e){
    var value=e.detail.value
    var pos=e.detail.cursor
    if(pos!=-1){
      //光标在中间
      var left=e.detail.value.slice(0,pos)
      //计算光标的位置
      pos=left.replace(/11/g,'2').height
    }
    //直接返回对象,可以对输入进行过滤处理,同时可以控制光标位置
    return{
      value:value.replace(/11/g,'2'),
      cursor:pos
    }
    //或者直接返回字符串,光标在最后面
    //return value.replace(/11/g,'2'),
  }
})

 运行效果如下:

 4.4.9 textarea

textarea 组件为多行输入框组件,可以实现多行内容的输入。textarea组件的属性如表所示。

textarea组件属性

 代码如下:

//wxml
<textarea bindblur="bindTextAreaBlur" auto-height placeholder="自动变高"/>
<textarea placeholder="pplaceholder颜色是红色的" placeholder-style="color:red"/>
<textarea placeholder="这是一个可以自动聚焦的textarea" auto-focus/>
<textarea placeholder="这个只有在按钮点击的时候才聚焦" focus="{{focus}}"/>
<button bindtap="bindButtonTap">使得输入框获取焦点</button>
<form bindsubmit="bindFormSubmit">
<textarea placeholder="form中的textarea" name="textarea"/>
<button form-type="submit">提交</button>
</form>
//js
Page({
  data:{
   height:10,
   focus:false
  },
  bindButtonTap:function(){
    this.setData({
      focus:true
    })
  },
  bindTextAreaBlur:function(e){
    console.log(e.detail.value.textarea)
  }
})

 运行效果如下:

 4.4.10 label

label组件为标签组件,用于提升表单组件的可用性。label组件支持使用for属性找到对应的id或者将控件放在该标签下,当点击label组件时就会触发对应的控件。for属性的优先级高于内部控件,内部有多个控件的时候默认触发第一个控件。目前,label 组件可以绑定的控件有<button/>,<checkbox/>,<radio>、<switch/> 

代码如下:

//wxml
<!---单击中国不能选择/取消复选框-->
<view><checkbox></checkbox>中国</view>
<!---单击“中国”不能选择/取消复选框-->
<view><label><checkbox></checkbox>中国</label></view>
<!---使用for找到对应的id-->
<checkbox-group bindchange="cityChange">
<label wx:for="{{citys}}">
<checkbox value="{{item.value}}" checked='{{item.checked}}'>{{item.value}}</checkbox>
</label>
</checkbox-group>
<view>你的选择:{{city}}</view>
//js
Page({
    city:"",
    data:{
      citys:[
      {name:'km',value:'昆明'},
      {name:'sy',value:'三亚'},
      {name:'zh',value:'珠海',checked:'true'},
      {name:'dl',value:'大连'}
    ] 
  },
    cityChange:function(e){
      console.log(e.detail.value);
      var city=e.detail.value;
      this.setData({city:city})
     }
  })

 运行效果如下:

4.4.11 form

form 组件为表单组件,用来实现将组件内的用户输人信息进行提交。当<form/>表单中formType图4-20 label 组件运行效果示意为submi 的<buton/>组件时,会将表单组件中的value 值进行提交。form组件的属性如表所示。

 代码如下:

//wxml
<form bindsubmit="formSubmit" bindreset="formReset">
<view>姓名:
<input type="text" name="xm"/>
</view>
<view>姓名:
<radio-group name="xb">
<label>
<radio value="男" checked/>男
</label>
<label>
<radio value="女"/>女
</label>
</radio-group>
</view>
<view>爱好:
<checkbox-group name="hobby">
<label wx:for="{{hobbies}}">
<checkbox value="{{item.value}}"
checked='{{item.checked}}'>{{item.value}}</checkbox>
</label>
</checkbox-group>
</view>
<button formType='Submit'>提交</button>
<button formType='reset'>重置</button>
</form>
//js
Page({
     hobby:'',
    data:{
       hobbies:[
         {name:'jsj',value:'计算机',checked:'true'},
         {name:'music',value:'听音乐'},
         {name:'game',value:'玩电竞'},
         {name:'swim',value:'游泳',checked:'true'} ]

     },
  formSubmit:function(e){
    console.log('from发生了 submit 事件,携带数据为:',e.detail.value)
  },
  formReset:function(e){
    console.log('form发生了reset事件')
  }
  })

 运行效果如下:

4.5 多媒体组件

多媒体组件包括image(图像)、audio(音频)、video(视频)、camera(相机)组件使用这些组件,可以让页面更具有吸引力

4.5.1 image

image组件为图像组件,与HTML中的<img/>类似,系统默认image 组件的宽度为300p、高度为2250px,image组件的属性如表所示

 代码如下:

//wxml
<block wx:for="{{modes}}">
<view>当前图片的模式是:{{item}}</view>
<image mode="{{item}}" src="/images/j4.jpg" style="width: 100% , height: 100%"/>
</block>
//js
Page({
    
    data:{
     modes:['scaleToFill','aspectFit','aspectFll','widthFix']
  }
  })

 运行效果如下:

2.剪裁模式

■top 不缩放图片,只显示图片的顶部区域。
■bottom 不缩放图片,只显示图片的底部区域
■center 不缩放图片,只显示图片的中间区域
■lef 不缩放图片,只显示图片的左边区域。
■night 不缩放图片,只显示图片的右边区域。
 ■top_lef不缩放图片,只显示图片的左上边区域top_lef
■top_right不缩放图片,只显示图片的右上边区域
■bottom_left不缩放图片,只显示图片的左下边区域
■bottom_right不缩放图片,只显示图片的右下边区域

代码如下:

//wxml
<block wx:for="{{modes}}">
<view>当前图片的模式是:{{item}}</view>
<image mode="{{item}}" src="/images/j4.jpg" style="width: 100%,height:100%"/>
</block>
//ja
Page({
    
    data:{
     modes:['stop','center','bottom','left','right','top_left','top_right','bottom_left','bottom_right']
  }
  })

 运行效果如下:

4.5.2 audio

audio组件用来实现音乐播放、暂停等,其属性如表所示。

 

4.5.3 video

video组件用来实现视频的播放、暂停等。视频的默认宽度为300px,高度为225pxdideo 组件的属性如表所示

video组件属性

示例代码如下: 

//wxml

<video src="{{src}}"controls></video>
<view class="btn-area">
<button bindtap="bindButtonTop">获取视频</button>
</view>
//js
Page({
    
    data:{
        src:'',
  },
  bindButtonTap:function(){
    var that=this
    wx.chooseVideo({
      sourceType:['album','camera'],
      maxDuration:60,
      camera:['front','back'],
      success:function(res){
        that.setData({
          src:res.tempFilePath
        })
      }
    })
  }
  })

 运行效果如下:

4.5.4 camera 

camera组件为系统相机组件,可以实现拍照或录像功能。在一个页面中,只能有一个camera组件。在开发工具中运行时,使用电脑摄像头实现拍照或录像;在手机中运行时,使用手机前后摄像头实现拍照或录像camera 组件的属性如表所示

camera组件属性

 示例代码如下:

//wxml
<camera device-position="back" flash="off" binderror="error" style="width:100%;height:350px;"></camera>
<button type="primary" bindtap="takePhoto">拍照</button>
<view>预览</view>
<image mode="widthFix" src="{{src}}"></image>
//js
Page({
    takePhoto(){
    const ctx=wx.createCameraContext()
    ctx.takePhoto({
      quality:'high',
      success:(res)=>{
        this.setData({
          src:res.tempImagePath
        })
      }
    })
  },
   error(e){
    console.log(e.detail)
  }
  })

 运行效果如下:

 

4.6.1 map 

map组件用于在页面中显示地图或路径,常用于LBS(基于位置服务)或路径指引,功能相对百度地图、高德地图较简单,目前具备绘制图标、路线、半径等能力,不能在crolview.swiper.picker-view、movable-view组件中使用

map组件属性

map组件markers属性的相关属性 

     map组件polyline属性的相关属性

 示例代码如下:

//wxml
<map id="map"
longitude="108.9200"
latitude="34.1550"
scale="14"
controls="{{controls}}"
bindcontroltap="controltap"
markers="{{markers}}"
bindmarkertap="markertap"
polyline="{{polyline}}"
bindregionchange="regionchange"
show-location
style="width: 100%;height: 300px;">
</map>
//js
Page({
   data:{
    markers:[{
      iconPath:"/images/j7.jpg",
      id:0,
      longitude:"108.9290",
      latitude:"34.1480",
      width:50,
      height:50
    }],
    polyline:[{
      points:[
        {
          longitude:"108.9200",
          latitude:"34.1400",
        },
        {
          longitude:"108.9200",
          latitude:"34.1500"
        },
        {
          longitude:"108.9200",
          latitude:"34.1700"
        }
      ],
      color:"#00ff00",
      width:2,
      dottedLine:true
    }],
    controls:[{
      id:1,
      iconPath:'/images/j4.jpg',
      position:{
        left:0,
        top:300,
        width:30,
        height:30
      },
      clickable:true
    }]
  },
  regionchange(e){
    console.log(e.type)
  },
  markertap(e){
    console.log(e.markerId)
  },
  controltap(e){
    console.log(e.controlId)
  }
  })

 运行效果下:

 

 4.6.2 canvas

canvas组件用来绘制图形,相当于一块无色透明的普通图布。canvas组件本身并没有绘图能力,仅仅是图形容器,通过绘图API实现绘图功能。在默认情况下,canvas组件的默认宽度为300px,高度为225px,同一页面中的canvas-id不能重复,否则会出错。canvas 组件的属性如下表:

示例代码如下 : 

//wxml
<canvas canvas-id="myCanvas" style="border: 1px solid red;"/>
//js
Page({
   onLoad:function(options){
    var ctx=wx.createCanvasContext('myCanvas')
    ctx.setFillStyle('green')
    ctx.fillRect(10,10,200,100)
    ctx.draw()
  }
  })

 运行效果

 

  • 31
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
深入解析Windows操作系统 4/5 第1章 概念和工具 1.1 Windows操作系统的版本 1.2 基础概念和术语 1.3 挖掘Windows内部机理 1.4 本章总结 第2章 系统结构 2.1 需求和设计目标 2.2 操作系统模型 2.3 总体结构 2.4 关键的系统组件 2.5 本章总结 第3章 系统机制 3.1 陷阱分发 3.2 对象管理器 3.3 同步 3.4 系统辅助线程 3.5 Windows全局标志 3.6 本地过程调用(LPC) 3.7 内核事件追踪 3.8 Wow64 3.9 本章总结 第4章 管理机制 4.1 注册表 4.2 服务 4.3 Windows管理规范 4.4 本章总结 第5章 启动和停机 5.1 引导过程 5.2 引导和启动问题的故障检查 5.3 停机 5.4 本章总结 第6章 进程、线程和作业 6.1 进程的内部机理 6.2 CreateProcess的流程 6.3 线程的内部机理 6.4 检查线程活动 6.5 线程调度 6.6 作业对象 6.7 本章总结 第7章 内存管理 7.1 内存管理器简介 7.2 内存管理器提供的服务 7.3 系统内存池 7.4 虚拟地址空间的布局结构 7.5 地址转译 7.6 页面错误处理 7.7 虚拟地址描述符 7.8 内存区对象 7.9 工作集 7.10 逻辑预取器 7.11 页面帧编号数据库 7.12 本章总结 第8章 安全性 8.1 安全系统组件 8.2 保护对象 8.3 账户权限和特权 8.4 安全审计 8.5 登录(Logon) 8.6 软件限制策略 8.7 本章总结 第9章 I/O系统 9.1 I/O系统组件 9.2 设备驱动程序 9.3 I/O处理 9.4 即插即用(PnP)管理器 9.5 电源管理器 9.6 本章总结 第10章 存储管理 10.1 有关存储的术语 10.2 磁盘驱动程序 10.3 卷的管理 10.4 本章总结 第11章 缓存管理器 11.1 缓存管理器的关键特性 11.2 缓存的虚拟内存管理 11.3 缓存的大小 11.4 缓存的数据结构 11.5 文件系统接口 11.6 快速I/O 11.7 预读(Read Ahead)和滞后写(Write Behind) 11.8 本章总结 第12章 文件系统 12.1 Windows文件系统格式 12.2 文件系统驱动程序总体结构 12.3 诊断文件系统的问题 12.5 NTFS文件系统驱动程序 12.6 NTFS在磁盘上的结构 12.7 NTFS的恢复支持 12.8 加密文件系统(EFS)安全性 12.9 本章总结 第13章 网络 13.1 Windows的网络总体结构 13.2 网络API 13.3 多重定向器支持 13.4 名称解析 13.5 协议驱动程序 13.6 NDIS驱动程序 13.7 绑定 13.8 分层的网络服务 13.9 本章总结 第14章 崩溃转储分析 14.1 Windows为什么会崩溃 14.2 蓝屏 14.3 崩溃转储文件 14.4 Windows错误报告 14.5 在线崩溃分析 14.6 基本的崩溃转储分析 14.7 使用崩溃诊断工具 14.8 高级的崩溃转储分析 术语表 术语对照表 索引
第1章 服务器控件概述及开发环境部署 .1 1.1 自定义服务器控件 1 1.2 服务器控件在软件开发过程中的作用 1 1.3 在控件开发中提升自己 2 1.4 可继承控件基类介绍 2 1.5 运行一个简单的控件 7 1.5.1 开发一个简单控件 7 1.5.2 部署和运行 11 1.6 控件生命周期 12 1.6.1 概述 12 1.6.2 用代码跟踪控件生命周期过程 14 1.7 本章总结 17 第2章 服务器控件开发中的调试技术 18 2.1 预置代码示例 18 2.2 调试页面服务端代码 19 2.3 服务器控件的调试 20 2.3.1 运行模式下的调试方法 20 2.3.2 设计模式下的调试方法 20 2.4 javascript脚本调试方法 22 2.4.1 调试页面中的javascript脚本(方法一) 22 .2.4.2 调试页面中的javascript脚本(方法二) 23 2.4.3 调试非嵌入式javascript脚本文件 23 2.4.4 调试嵌入式javascript脚本资源文件 24 2.4.5 高效率调试的技巧 24 2.5 ajax library对javascript调试支持 26 2.6 本章总结 26 第3章 从零开始开发服务器控件 27 3.1 选择基类 27 3.2 控件呈现顺序 28 3.3 render呈现控件的几种方式 30 3.3.1 使用htmltextwriter类输出 30 3.3.2 直接输出html标签 32 3.3.3 使用服务器控件的rendercontrol方法 33 3.4 addattributestorender方法 34 3.5 createchildcontrols方法 35 3.6 inamingcontainer接口 36 3.7 实现复合控件 38 3.7.1 createchildcontrols方法 39 3.7.2 childcontrolscreated属性 39 3.7.3 ensurechildcontrols方法 39 3.7.4 recreatechildcontrols方法 39 3.7.5 controls属性 40 3.7.6 hascontrols方法 40 3.7.7 hasevents方法 40 3.7.8 findcontrol方法 41 3.7.9 实现复合控件示例 41 3.8 常用开发技巧 51 3.8.1 designmode属性 51 3.8.2 屏蔽基类控件中的属性 52 3.8.3 page.request.browser属性 53 3.8.4 设置控件id规范 53 3.8.5 增强findcontrol功能 54 3.8.6 映射服务端控件值到客户端 55 3.8.7 禁止派生自compositecontrol的控件创建子控件 56 3.8.8 使用createchildcontrols的注意事项 56 3.8.9 不要误解设计元属性defaultvalue 57 3.8.10 在render方法中利用基类资源 57 3.8.11 条件编译&条件属性 60 3.9 本章总结 61 第4章 服务器控件属性 62 4.1 控件属性的作用 62 4.1.1 系统属性 62 4.1.2 自定义属性 62 4.2 简单属性 63 4.3 属性的设计时特性 64 4.4 复杂属性 67 4.4.1 概述 67 4.4.2 复杂属性的几种标记形式 67 4.4.3 深入研究——复杂属性分析器 79 4.5 深入研究——定制自己的属性编辑器 85 4.5.1 系统属性编辑器 85 4.5.2 定制属性编辑器 91 4.6 类型转换器 126 4.6.1 系统类型转换器 126 4.6.2 定制自己的类型转换器 128 4.7 实现自定义属性 138 4.8 本章总结 145 第5章 事件和数据回发机制 146 5.1 控件事件和数据回发概述 146 5.1.1 事件及其意义 146 5.1.2 数据回发机制 147 5.2 事件和数据回发机制的实现 148 5.2.1 客户端回传事件接口ipostbackeventhandler 148 5.2.2 客户端回发/回调揭密 150 5.2.3 回传数据处理接口ipostbackdatahandler 153 5.2.4 正确处理继承基类中控件的事件 159 5.2.5 扩展kingtextbox控件功能(kingtextboxcanpostevent控件) 161 5.3 复合控件的事件处理机制
《深入解析Windows操作系统》中文版 第四版 1/5 第1章 概念和工具 1.1 Windows操作系统的版本 1.2 基础概念和术语 1.3 挖掘Windows内部机理 1.4 本章总结 第2章 系统结构 2.1 需求和设计目标 2.2 操作系统模型 2.3 总体结构 2.4 关键的系统组件 2.5 本章总结 第3章 系统机制 3.1 陷阱分发 3.2 对象管理器 3.3 同步 3.4 系统辅助线程 3.5 Windows全局标志 3.6 本地过程调用(LPC) 3.7 内核事件追踪 3.8 Wow64 3.9 本章总结 第4章 管理机制 4.1 注册表 4.2 服务 4.3 Windows管理规范 4.4 本章总结 第5章 启动和停机 5.1 引导过程 5.2 引导和启动问题的故障检查 5.3 停机 5.4 本章总结 第6章 进程、线程和作业 6.1 进程的内部机理 6.2 CreateProcess的流程 6.3 线程的内部机理 6.4 检查线程活动 6.5 线程调度 6.6 作业对象 6.7 本章总结 第7章 内存管理 7.1 内存管理器简介 7.2 内存管理器提供的服务 7.3 系统内存池 7.4 虚拟地址空间的布局结构 7.5 地址转译 7.6 页面错误处理 7.7 虚拟地址描述符 7.8 内存区对象 7.9 工作集 7.10 逻辑预取器 7.11 页面帧编号数据库 7.12 本章总结 第8章 安全性 8.1 安全系统组件 8.2 保护对象 8.3 账户权限和特权 8.4 安全审计 8.5 登录(Logon) 8.6 软件限制策略 8.7 本章总结 第9章 I/O系统 9.1 I/O系统组件 9.2 设备驱动程序 9.3 I/O处理 9.4 即插即用(PnP)管理器 9.5 电源管理器 9.6 本章总结 第10章 存储管理 10.1 有关存储的术语 10.2 磁盘驱动程序 10.3 卷的管理 10.4 本章总结 第11章 缓存管理器 11.1 缓存管理器的关键特性 11.2 缓存的虚拟内存管理 11.3 缓存的大小 11.4 缓存的数据结构 11.5 文件系统接口 11.6 快速I/O 11.7 预读(Read Ahead)和滞后写(Write Behind) 11.8 本章总结 第12章 文件系统 12.1 Windows文件系统格式 12.2 文件系统驱动程序总体结构 12.3 诊断文件系统的问题 12.5 NTFS文件系统驱动程序 12.6 NTFS在磁盘上的结构 12.7 NTFS的恢复支持 12.8 加密文件系统(EFS)安全性 12.9 本章总结 第13章 网络 13.1 Windows的网络总体结构 13.2 网络API 13.3 多重定向器支持 13.4 名称解析 13.5 协议驱动程序 13.6 NDIS驱动程序 13.7 绑定 13.8 分层的网络服务 13.9 本章总结 第14章 崩溃转储分析 14.1 Windows为什么会崩溃 14.2 蓝屏 14.3 崩溃转储文件 14.4 Windows错误报告 14.5 在线崩溃分析 14.6 基本的崩溃转储分析 14.7 使用崩溃诊断工具 14.8 高级的崩溃转储分析 术语表 术语对照表 索引

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值