前言
本文主要给大家介绍的是关于利用Ionic2 + angular4实现一个地区选择组件的相关内容,为什么会有这篇文章?主要是因为最近在项目重构的过程中,发现之前用mobiscroll写的地区选择指令在angular2中很难重用(毕竟是用typeScript)。于是就萌生了自己写一个组件的想法。
想和之前一样基于mobiscroll去写,但是发现非常耗费精力,于是某日万般无奈这下搜了一下相关的组件,不出所料已经有人写了。https://www.npmjs.com/package...但是此组件并不符合我的要求。我不是单纯的选择省市区,还可能是选择省市或者省。于是参照此项目基于ionic2的picker写了一个公用组件。下面话不多说了,感兴趣的朋友们下面来一起看看详细的介绍:
具体代码如下:
AreasSelect.ts
import {PickerController} from "ionic-angular"; import {Component, EventEmitter, Output, Input} from "@angular/core"; import {areasList} from "../../datasource/areas"; @Component({ selector: 'areas-select', templateUrl: 'areasSelect.com.html', }) export class AreasSelect { constructor(protected Picker: PickerController) { } private picker; private provinceCol = 0; // 省列 private cityCol = 0; // 市列 private regionCol = 0; // 区列 private pickerColumnCmps; // picker纵列数据实例 private isOpen = false; // 是否被创建 private pickerCmp; // picker 实例 private value = ''; // 选中后的数据 @Input() citiesData = areasList; // 地区数据(默认为areas.ts的数据) @Input() cancelText = '关闭'; // 关闭按钮文本 @Input() doneText = '完成'; // 完成按钮文本 @Input() separator = ''; // 数据衔接模式 @Input() level = 3; // 等级设置 最高为三级 /** * 关闭时触发的事件 * 没有值返回 * @type {EventEmitter} */ @Output() cancel: EventEmitter<any> = new EventEmitter(); // 关闭事件 /** * 完成时触发的事件 * 返回值为obj * obj = {data: object,value: string} data为对应的省市区和编码 * @type {EventEmitter} */ @Output() done: EventEmitter<any> = new EventEmitter(); // 完成事件 /** * 打开地区选择器 * 基本思路 * 1.创建picker * 2. 先把数据处理成省市区分开的数组 * 3. 将数据以列的形式给到picker * 4. 设置数据显示样式(picker) * 5. 生成picker */ private open() { let pickerOptions = { buttons: [ { text: this.cancelText, role: 'cancel', handler:() => { this.cancel.emit(null); } }, { text: this.doneText, handler: (data) =>{ this.onChange(data); this.done.emit({ data: data, value: this.value }); } } ] }; this.picker = this.Picker.create(pickerOptions); this.generate();// 加载 this.validate(this.picker); // 渲染 this.picker.ionChange.subscribe(() => { this.validate(this.picker); }); // 生成 this.picker.present(pickerOptions).then(() => { this.pickerCmp = this.picker.instance; this.pickerColumnCmps = this.pickerCmp._cols.toArray(); this.pickerColumnCmps.forEach(function (col) { return col.lastIndex = -1; }); }); this.isOpen = true; this.picker.onDidDismiss(function () { this.isOpen = false; }); } /** 对数据进行处理,并移交给picker * */ private generate() { let values = this.value.toString().split(this.separator); // Add province data to picker let provinceCol = { name: 'province', options: this.citiesData.map(function (province) { return {text: province.name, value: province.code, disabled: false}; }), selectedIndex: 0 }; let provinceIndex = this.citiesData.findIndex(function (option) { return option.name == values[0]; }); provinceIndex = provinceIndex === -1 "px"; } else if (columns.length === 3) { let width = Math.max(columns[0], columns[2]); pickerColumns[0].align = 'right'; pickerColumns[1].columnWidth = columns[1] * 33 + "px"; pickerColumns[0].optionsWidth = pickerColumns[2].optionsWidth = width * 17 + "px"; pickerColumns[2].align = 'left'; } } /** * 验证数据 * @param picker */ private validate(picker) { let _this = this; let columns = picker.getColumns(); let provinceCol = columns[0]; let cityCol = columns[1]; let regionCol = columns[2]; if (cityCol && this.provinceCol != provinceCol.selectedIndex) { cityCol.selectedIndex = 0; let cityColData = this.citiesData[provinceCol.selectedIndex].children; cityCol.options = cityColData.map(function (city) { return {text: city.name, value: city.code, disabled: false}; }); if (this.pickerColumnCmps && cityCol.options.length > 0) { setTimeout(function () { return _this.pickerColumnCmps[1].setSelected(0, 100); }, 0); } } if (regionCol && (this.cityCol != cityCol.selectedIndex || this.provinceCol != provinceCol.selectedIndex)) { let regionData = this.citiesData[provinceCol.selectedIndex].children[cityCol.selectedIndex].children; regionCol.selectedIndex = 0; regionCol.options = regionData.map(function (city) { return {text: city.name, value: city.code, disabled: false}; }); if (this.pickerColumnCmps && regionCol.options.length > 0) { setTimeout(function () { return _this.pickerColumnCmps[2].setSelected(0, 100); }, 0); } } this.provinceCol = provinceCol.selectedIndex; this.cityCol = cityCol "" + newData['province'].text + this.separator + (newData['city'].text || '') + this.separator + (newData['region'].text || ''); } return "" + newData['province'].text + this.separator + (newData['city'].text || ''); } return "" + newData['province'].text; } }
areasSelect.com.html
其实是不需要对应的template的,但是为了能和父级传参,这里创建了一个空的template
<div></div>
具体用法:
在需要用到的页面调用
test.page.html
<ion-content> <button ion-button block icon-left color="light" (tap)="showAreasSelect()">地区选择</button> </ion-content> <areas-select #areasSelect [level]="3" (cancel)="closeSelect()" (done)="done($event)"></areas-select>
test.page.ts
import {Component, ElementRef, Injector, ViewChild} from "@angular/core"; import {BasePage} from "../base.page"; @Component({ templateUrl: 'test.page.html', styles: [] }) export class TestPage extends BasePage { constructor(protected rt: ElementRef, protected ij: Injector) { super(rt, ij); } @ViewChild('areasSelect') areasSelect; showAreasSelect() { this.areasSelect.open(); } done(data) { this.showAlert(JSON.stringify(data)); } closeSelect() { this.showAlert('you click close'); } }
没有地区数据json或ts的文件可以去这里获取:http://xiazai.jb51.net/201707/yuanma/regional_data(jb51.net).rar
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 【雨果唱片】中国管弦乐《鹿回头》WAV
- APM亚流新世代《一起冒险》[FLAC/分轨][106.77MB]
- 崔健《飞狗》律冻文化[WAV+CUE][1.1G]
- 罗志祥《舞状元 (Explicit)》[320K/MP3][66.77MB]
- 尤雅.1997-幽雅精粹2CD【南方】【WAV+CUE】
- 张惠妹.2007-STAR(引进版)【EMI百代】【WAV+CUE】
- 群星.2008-LOVE情歌集VOL.8【正东】【WAV+CUE】
- 罗志祥《舞状元 (Explicit)》[FLAC/分轨][360.76MB]
- Tank《我不伟大,至少我能改变我。》[320K/MP3][160.41MB]
- Tank《我不伟大,至少我能改变我。》[FLAC/分轨][236.89MB]
- CD圣经推荐-夏韶声《谙2》SACD-ISO
- 钟镇涛-《百分百钟镇涛》首批限量版SACD-ISO
- 群星《继续微笑致敬许冠杰》[低速原抓WAV+CUE]
- 潘秀琼.2003-国语难忘金曲珍藏集【皇星全音】【WAV+CUE】
- 林东松.1997-2039玫瑰事件【宝丽金】【WAV+CUE】