4.1组件的定义及属性

每一个组件都由一对标签组成,有开始标签和结束标签,内容放置在开始标签和结束标 签之间,内容也可以是组件。组件的语法格式如下:

<标签名 属性名="属性值">内容……

组件通过属性来进一步细化。不同的组件可以有不同的属性,但它们也有一些共用属 性,如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.1 view

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

view组件的特有属性表如下:

示例代码如下:

wxml:

默认flex布局

1

2

3

上下混合布局

1

2

3

左右混合布局

1

2

3

完成效果图如下:

4.2.2 scroll-view

通过设置seroll-view组件的相关属性可以实现滚动视图的功能。

其属性如下图所示:

 通过serol-view 组件可以实现下拉刷新和上拉加载更多,代码如下:

wxml代码如下:

//index.wxml

style="height: {{scrollHeight}} px;" class="list" bind-scrolltolower="binsdDowLoad"

bindscrolltoupper="topLoad"bindscroll="scroll">

"

{{item.name}}>

{{item.short_description}}

加载中。。。。

wxss代码如下

//wxss

.userinfol{

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:300rpx;

margin:20rpxauto;

background:brown;

overflow:hidden;

}

.item.img{

width:430rpx;

margin-right:20rpx;

float:left;

}

.title{

font-size:30rpx;

display:block;

margin:30rpxauto;

}

.description{

font-size:26rpx;

line-height:15rpx;

}

js代码如下

//js

var url ="http://www.imooc.con/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_ia,

unlearn:unlearn

},

success:function(res){

var list=that.data.list;

for(var i=0;i

list.push(res.data.list[i]);

}

that.setData({

list:list

});

page ++;

that.setData({

hidden: true

});

}

});

}

Page({

data:{

hidden: true,

list:[],

scrol1Top:0,

scrollHeight: 0

},

onLoad: function(){

var that = this;

wx.getSystemInfo({

success: function(res){

that.setData({

scrol1Height: res. windowHeight

});

}

});

loadMore(that);

},

bindDownLoad: function(){

var that = this;

loadMore(that);

console.log("lower");

},

scroll: function(event){

this.setData({

scrollTop: event.detail.scrollTop

});

},

topLoad: function(event){

page =0;

this.setData({

list:[1],

scrollTop:0

});

loadMore(this);

console.log("lower");

}

})

4.2.3 swiper

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

 设置swiper组件,可以实现轮播图效果,代码如下:

//index.wxml:

//index.wxml

完成效果如下图:

4.3 基础内容组件

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

4.3.1 icon

icon组件即图标组件,通常用于表示一种状态,如success、info、warn、waiting、cancel等。

属性图如下所示:

 代码示例如下:

index.wxml代码如下:

//index.wxml

icon类型:

{{item}}

icon大小:

{{item}}

icon颜色:

{{item}}

 index.js代码如下:

//index.js

Page({

data:{

iconType:["success","success_no_circle","info","warn","waiting","cancel","download","search","clear"],

iconSize:[10,20,30,40],

iconColor:["#f00","#0f0","#00f"]

}

})

 完成效果如下:

4.3.2 text

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

 text组件属性

示例代码如下:

text.wxml代码如下:

//text.wxml

 

*

 

*

 text.js代码如下:

// text.js

Page({

data:{

x:[1,2,3,4,5],

y:[1,2,3,4,5,6,7,8,9]

}

})

 运行结果如下:

4.3.3 progress 

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

其属性如下图所示:

 示例代码如下:

index.wxml:

//index.wxml

显示百分比

改变宽度

自动显示进度条

完成效果如下:

4.4 表单组件

    表单组件的主要功能是收集用户信息,并将这些信息传递给后台服务器,实现小程序与用户之间的沟通。表单组件不仅可以放置在

标签中使用,还可以作为单独组件和其他组件混合使用。

4.4.1 button

button组件用来实现用户和应用之间的交互,同时按钮的颜色起引导作用。

button组件属性如下表所示:

示例代码如下:

wxml:

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'})

},

buttonSize:function(){

this.setData({plain:!this.data.plain})

},

buttonSize:function(){

this.setData({loading:!this.data.loading})

}

})

 完成效果如下:

4.2.2 radio

   单选框用来从一组选项中选取一个选项。在小程序中,单选框由(单项选择器)和(单选项目)两个组件组合而成,一个包含多个表示一组单选项,在同一组单选项中是互斥的,当一个按钮被选中后,之前选中的按钮就变为非选。

 它们的属性表如下:

 示例代码如下:

wxml:

//wxml

选择你喜爱的城市:

西安

北京

上海

广州

深圳

你的选择:{{city}}

{{item.name}}

你的选择:{{lang}}

 js:

//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});

},

radiochange:function(event){

this.setData({lang:event.detail.value})

}

})

 完成效果如下:

4.4.3 checkbox

复选框用于从一组选项中选取多个选项,小程序中复选框由< checkbox-group/>(多项择器)和(多选项目)两个组件组合而成。一个表示一组选项,可以在一组选项中选中多个选项。

它们的属性如下表所示:

示例代码如下:

wxml:

//wxml

选择你想要去的城市:

{{item.value}}

您的选择是:{{city}}

js:

//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.4 Switch

switch组件的作用类似开关选择器。

其属性如下表所示:

示例代码如下:

wxml:

//wxml

{{var1}}

{{var2}}

{{var3}}

js:

//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.5 slider

slider组件为滑动选择器,可以通过滑动来设置相应的值。

其属性表如下表所示:

示例代码如下:

wxml:

//wxml

默认 min=0 max=100 step=1

显示当前值

设置 min=20 max=200 step=10

背景条红色,已选定颜色绿色

滑动改变icon的大小

js:

//js

Page({

data:{

size:'20'

},

sliderchange:function(e){

this.setData({size:e.detail.value})

}

})

完成效果如下: 

 4.4.6 picker

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

1.普通选择器

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

 示例代码如下:

wxml代码如下:

//wxml

---range为数组---

当前选择:{{array[index1]}}

---range为数组对象---

当前选择:{{objArray[index2].name}}

 js代码如下:

//js:

Page({

data:{

array:["JAVA","Python","C","C#"],

objArray:[

{id:0,name:"JAVA"},

{id:1,name:"Python"},

{id:2,name:"C"},

{id:3,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代码如下:

//wxml:

多列选择器

range="{{multiArray}}">

当前选择:{{multiArray[0][multiIndex[0]]}},{{multiArray[1][multiIndex[1]]}},{{multiArray[2][multiIndex[2]]}}

 js代码如下:

//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.multiArryay,

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;

}

break;

}

data.multiIndex[2]=0;

console.log(data.multiIndex);

break;

}

this.setData(data);

},

})

完成效果如下:

3.时间选择器、日期选择器

时间选择器(mode=time)可以用于从提供的时间选项中选择相应的时间。

其属性如下表所示:

 日期选择器(mode=date)可以用于从提供的日期选项中选择相应的日期。

其属性如下表所示:

示例代码如下: 

wxml代码如下:

//wxml:

选择的日期:{{date}}

选择的时间:{{time}}

 js代码如下:

//js:

Page({

data:{

startdate:2000,

enddate:2050,

data:'2018',

starttime:'00:00',

endtime:'12:59',

time:'8:00'

},

changedate:function(e){

this.setData({data:e.detail.value});

console.log(e.detail.value)

},

changetime:function(e){

this.setData({time:e.detail.value})

console.log(e.detail.value)

}

})

运行效果如下:

4.省市选择器

 省市选择器(mode=region)是小程序的新版本提供的选择快速地区的组件。

其属性如下表所示 :

示例代码如下: 

wxml代码如下:

//wxml:

选择省市区:{{region[0]}},{{region[1]}},{{region[2]}}

 js代码如下:

//js:

Page({

data:{

region:['陕西省','西安市','长安区'],

customitme:'全部'

},

changeregion:function(e){

console.log(e.detail.value)

this.setData({

region:e.detail.value

})

}

})

运行效果如下:

 4.4.7 picker-view

 picker-view  组件为嵌入页面的滚动选择器。 相对于picker 组件, picker-view  组件的列的个数和列的内容由用户通过< picker-view  -column/ > 自定义设置。

picker-view组件如下表所示:

示例代码如下: 

wxml代码如下:

//wxml:

当前日期:{{year}}年{{month}}月{{day}}日

indicator-style="height:50px;"

style="width:100%;height:300px;"

value="{{value}}"bindchange="bindChange">

wx:for="{{years}}"

style="line-height:50px">

{{item}}年

wx:for="{{months}}"

style="line-height:50px">

{{item}}月

wx:for="{{days}}"

style="line-height:50px">

{{item}}日

 js代码如下:

//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:[118,0,0],

},

bindChange:function(e){

const val=e.detail.value

console.log(val);

this.setData({

year:this.data.years[val[0]],

month:this.data.months[val[1]],

day:this.data.days[val[2]]

})

}

})

运行效果如下:

4.4.8 input

input组件为输入框,用户可以输入相应的信息。

其属性如下表 :

示例代码如下: 

wxml代码如下:

//wxml:

你输入的是:{{inputValue}}

 js代码如下:

//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').length

}

return{

value:value.replace(/11/g,'2'),

cursor:pos

}

}

})

运行效果如下:

4.4.9 textarea

textarea组件为多行输入框组件,可以实现多行内容的输入。

textarea组件属性如下表: 

 示例代码如下:

wxml代码如下:

//wxml:

js代码如下:

//js:

Page({

data:{

height:10,

focus:false

},

bindButtonTap:function(){

this.setData({

focus:true

})

},

bindTextAreaBlur:function(e){

console.log(e.detail.value)

},

bindFormSubmit:function(e){

console.log(e.detail.value.textarea)

}

})

完成效果如下图:

4.4.10 ladel 

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

js代码如下:

//js:

Page({

hobby:'',

data:{

hobbies:[

{name:'jsj',value:'计算机',checked:'true'},

{name:'music',value:'听音乐'},

{name:'game',value:'玩电竞'},

{name:'swim',value:'游泳',checked:'true'}

]

},

forSubmit:function(e){

console.log('form发生了submit事件,携带数据为:',e.detail.value)

},

formReset:function(){

console.log('form发生了reset事件')

}

})

完成效果如下:

4.5 多媒体组件

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

4.5.1 image

image 组件为图像组件, 与HTML中的< img/ > 类似, 系统默认image 组件的宽度为300px、高度为2250px。

image组件的属性如下表:

  image组件中的mode属性有13种模式, 其中缩放模式有4种, 裁剪模式有9种。

1.缩放模式

 scaleToFill  不保持纵横比缩放图片, 使图片的宽高完全拉伸至填满image元素。  aspectFit  保持纵横比缩放图片, 使图片的长边能完全显示出来。 也就是说, 可以将图片完整地显示出来。  aspectFill  保持纵横比缩放图片, 只保证图片的短边能完全显示出来。 也就是说,图片通常只在水平或垂直方向是完整的, 在另一个方向将会发生截取。  widthFix  宽度不变, 高度自动变化, 保持原图宽高比不变。

示例代码如下:

wxml代码如下:

当前图片的模式是:{{item}}

js代码如下:

Page({

data:{

modes:['scaleToFill','aspectFit','aspectFill','widthFix']

}

})

完成效果如下:

 2.裁剪模式

top不缩放图片, 只显示图片的顶部区域。

 bottom 不缩放图片, 只显示图片的底部区域。

 center不缩放图片, 只显示图片的中间区域。

 left 不缩放图片, 只显示图片的左边区域。

 right 不缩放图片, 只显示图片的右边区域。

 top-left 不缩放图片, 只显示图片的左上边区域。

 top-right 不缩放图片, 只显示图片的右上边区域。

 bottom-right 不缩放图片, 只显示图片的左下边区域。

示例代码如下:

wxml代码如下:

当前图片的模式是:{{item}}

js代码如下:

Page({

data:{

modes:['top','center','bottom','left','right','top_left','top_right','bottom_right','bottom_right']

}

})

完成效果如下:

4.5.2 audio

audio组件用来实现音乐播放、暂停等。

其属性如下表:

示例代码如下:

wxml代码如下:

js代码如下:

Page({

data:{

poster:'http://y.gtimg.cn/music/photo_new/T002R300x300M000003rsKF44GyaSK.jpg? max_age=2592000',

name:'此时此刻',

author:'许巍',

src:'http://ws.stream.qqmusic.qq.com/M500001VfvsJ21xFqb.mp3? guid= ffffffff82def4af4b12b3cd9337d5e7&uin=346897220&vkey =6292F51E1E384E06DCBDC9AB7C49FD713D632D313AC4858BACB8DDD29067D3C601481D36E62053BF8 DFEAF74 C0A5CCFADD6471160CAF3E6A&from tag=46'

},

play:function(){

this.setData({

action:{

method:'play'

}

})

},

pause:function(){

this.setData({

action:{

method:'pause'

}

})

},

playRate:function(){

this.setData({

action:{

method:'setPlaybackRate',

data:10

}

})

console.log('当前速率:'+this.data.action.data)

},

currentTime:function(e){

this.setData({

action:{

method:'setCurrentTime',

data:120

}

})

}

})

完成效果如下:

4.5.3 video

 video组件用来实现视频的播放、暂停等。

其属性如下表:

示例代码如下:

wxml代码如下:

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 组件。 在开发工具中运行时, 使用电脑摄像头实现拍照或录像; 在手机中运行时, 使用手机前后摄像头实现拍照或录像。

其属性如下表:

示例代码如下:

wxml代码如下:

预览

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 其他组件

在小程序中,除了前面介绍的组件以外,map组件和canvas组件比较常用。

4.6.1 map

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

其属性如下表:

 map组件的markers属性用于地图上显示标记的位置,其相关属性表如下:

 map 组件的 polyline  属性用来指定一系列坐标点,从数组第一项连线到最后一项,形成一条路线,可以指定线的颜色、宽度、线型以及是否带箭头等。

其相关属性表如下:

示例代码如下:

wxml代码如下:

longitude="108.9200"

latitude="34.1550"

scale="14"

controls="{{controls}}"

bindcontroltap="controlstap"

markers="{{markers}}"

bindmarkertap="markertap"

polyline="{{polyline}}"

bindregionchange="regionchange"

show-location style="width: 100%;height: 300px;">

js代码如下:

Page({

data:{

markers:[{

iconPath:"/images/1.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/2.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不能重复,否则会出错。

组件属性如下表:

(1)创建一个canvas绘图上下文。

var context=wx.createCanvasContext('MyCanvas')

(2)使用canvas绘图上下文进行绘图描述。

context.setFillStyle('green')//设置绘图上下文的填充色为绿色

context.fillRect(10,10,200,100)//方法画一个矩形,填充为设置的绿色

(3)画图。

context.draw()

示例代码如下:

sxml:

js:

Page({

onLoad:function(options){

var ctx=wx.createCanvasContext('myCanvas')

ctx.setFillStyle('green')

ctx.fillRect(10,10,200,100)

ctx.draw()

}

})

完成效果如下图:

 

文章来源

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: