Ionic3学习笔记(十一)实现省市区三级联动

来源:互联网 发布:汽车行业设计软件 编辑:程序博客网 时间:2024/05/16 17:52

本文为原创文章,转载请标明出处

目录

  1. 安装 ion-multi-picker
  2. 导入 app.module.ts
  3. 创建 provider
  4. 创建 page
  5. 一个坑
  6. 更多
  7. 效果图

1. 安装 ion-multi-picker

终端运行:

npm install ion-multi-picker@2.1.0 --save

2. 导入 app.module.ts

...import {MultiPickerModule} from 'ion-multi-picker';...@NgModule({  ...  imports: [    ...    MultiPickerModule,    ...  ]  ...})...

3. 创建 provider

终端运行:

ionic g provider city-data

省市区json文件下载地址:
https://raw.githubusercontent.com/raychenfj/ion-multi-picker/master/example/src/assets/chinese-cities.json

将json值赋给下面的 cities 变量即可。

city-data.ts:

import {Injectable} from '@angular/core';@Injectable()export class CityDataProvider {  cities: any[];  constructor() {    this.cities = 上面的json(太长我就不复制粘贴了)  }}

4. 创建 page

终端运行:

ionic g page edit

edit.html

<ion-header>  <ion-navbar>    <ion-title>编辑</ion-title>    <ion-buttons end>      <button ion-button>保存</button>    </ion-buttons>  </ion-navbar></ion-header><ion-content>  <ion-list>    <ion-item>      <ion-icon name="pin" item-start></ion-icon>      <ion-label>居住地</ion-label>      <ion-multi-picker item-content [multiPickerColumns]="cityColumns" [cancelText]="'取消'" [doneText]="'完成'"></ion-multi-picker>    </ion-item>  </ion-list></ion-content>

edit.ts

import {Component} from '@angular/core';import {IonicPage, NavController, NavParams} from 'ionic-angular';import {CityDataProvider} from "../../providers/city-data/city-data";@IonicPage()@Component({  selector: 'page-edit',  templateUrl: 'edit.html',})export class EditPage {  cityColumns: any[];  constructor(public navCtrl: NavController, public navParams: NavParams, public cityDataProvider: CityDataProvider) {    this.cityColumns = this.cityDataProvider.cities;  }}

5. 一个坑

错误如下:

Uncaught (in promise): Error: Template parse errors:Can't bind to 'multiPickerColumns' since it isn't a known property of 'ion-multi-picker'.1. If 'ion-multi-picker' is an Angular component and it has 'multiPickerColumns' input, then verify that it is part of this module.2. If 'ion-multi-picker' is a Web Component then add 'CUSTOM_ELEMENTS_SCHEMA' to the '@NgModule.schemas' of this component to suppress this message.3. To allow any property add 'NO_ERRORS_SCHEMA' to the '@NgModule.schemas' of this component.

为啥就报错了咩…明明什么都没有错…

最终我在这个 Issue 中找到了解决方案。

因为我的这个页面是子页面,所以也要将 MultiPickerModule 导入子module一下。如果是根页面的话就没有问题。

edit.module.ts:

import { NgModule } from '@angular/core';import { IonicPageModule } from 'ionic-angular';import { EditPage } from './edit';import {MultiPickerModule} from 'ion-multi-picker';@NgModule({  declarations: [    EditPage,  ],  imports: [    MultiPickerModule,    IonicPageModule.forChild(EditPage),  ],})export class EditPageModule {}

6. 更多

GitHub - ion-multi-picker

7. 效果图

iOS:
iOS

Android:
Android

如有不当之处,请予指正,谢谢~

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 企业因为经营不善要降薪该怎么办 调岗不降薪我该怎么办? 怀孕后强制调岗怎么办 有限公司法人变更后债务怎么办 有限公司法人跑路债务怎么办 网上买票身份信息待核验怎么办 微信买票身份核验失败怎么办 买高铁票待核验怎么办 网上购票身份待核验怎么办 b站稿件版权原因怎么办 已离职老板打电话说账有问题怎么办 开到应急刹车道怎么办 自动挡的车刹车失灵怎么办 自动挡的车如果刹车失灵怎么办 手动挡汽车刹车失灵怎么办 车辆没有年检出了交通事故怎么办 跟着大货车闯了红灯怎么办 在万家金服买的电子产品坏了怎么办 汽车被油笔画了怎么办? 挂到别人车跑了怎么办 浪琴手表保修卡掉了怎么办 事故车辆维修和报废怎么办 4.2货车拉缸了怎么办 工作中与同事发生矛盾怎么办 和领导关系闹僵怎么办 内倒窗户卡住了怎么办 支付宝存在安全风险怎么办 地铁车站空调坏了怎么办 面试防汛值班发生灾情你怎么办 怀孕上班路途太远怎么办 硕士错过校招应该怎么办 收银员收多了钱怎么办 商铺贷款批不了怎么办 铁路局的门面乱收房租怎么办 酒店夜审房费多过怎么办 夜审房价录多了怎么办 做工地拿不到钱怎么办 赢了官司拿不到钱怎么办 工地上拿不到钱怎么办 做了工拿不到钱怎么办 高速公路上车没油了怎么办