ionic3項目實戰(zhàn)教程 - 第6講 ionic3 component 組建封裝

這一講主要包含以下幾個部分:

  • 1.創(chuàng)建ionic component
  • 2.使用ionic component

1.創(chuàng)建ionic3組建

1.1 組建的創(chuàng)建

執(zhí)行 ionic g component ion-products ,等待30s左右衍慎,成功之后可以看到目錄會發(fā)生變化:

6-1.png

1.2 組建的數(shù)據(jù)交互

通過@Input()來實現(xiàn)數(shù)據(jù)交互率寡,ion-products.ts完整代碼如下:

ion-products.ts

import { NavController } from 'ionic-angular';
import { Component, Input } from '@angular/core';
@Component({
  selector: 'ion-products',
  templateUrl: 'ion-products.html'
})
export class IonProductsComponent {
  @Input() products: Array<any>;
  constructor(public navCtrl: NavController) {
    console.log('Hello IonProducts Component');
  }
  goDetails(item) {
    console.debug('go details...')
  }
} 

1.3 組建的html實現(xiàn)

將home.html中商品列表部分的代碼剪切到ion-products.html

ion-products.html

  <div class="product">
    <ion-row wrap>
      <ion-col tappable col-6 *ngFor="let p of products" (click)="goDetails(p)">
         ![]({{p.PictUrl}})
        <p>{{p.Title}}</p>
        <div class="list-price buy">
          <span class="price-new"><i>¥</i>{{p.ZkFinalPrice}}</span>
          <i class="del">¥<span>{{p.ReservePrice}}</span></i>
        </div>
      </ion-col>
    </ion-row>
  </div>

1.4 組建樣式的實現(xiàn)

將home.scss里關于商品樣式的代碼剪切到ion-products.scss

ion-products.scss

  ion-products {
  .product {
    ion-row {
      background-color: #efefef;
      font-family: "Helvetica Neue", Helvetica, STHeiTi, sans-serif;
      padding-top: 3px;
      ion-col {
        position: relative;
        background-color: white;
        border: 2px solid #efefef;
        border-radius: 2px;
        padding: 0px;
        p {
          margin: 0px;
          padding: 0px;
          width: 100%;
          font-size: 12px;
          font-family: "黑體-簡";
          font-weight: 300;
          color: #808080;
          height: 26px;
          line-height: 26px;
          background: rgba(255, 255, 255, 0.8);
          overflow: hidden;
          text-indent: 5px;
        }
      }
    }
    .list-price {
      width: 98%;
      height: 26px;
      line-height: 18px;
      position: relative;
      bottom: 0;
      margin: 0 2%;
    }
    .price-new {
      font-size: 18px;
      color: #f8285c;
    }
    .list-price i {
      font-style: normal;
      font-size: 12px;
    }
    .del {
      color: rgba(171, 171, 171, 1);
      text-decoration: line-through;
      margin-left: 2px;
    }
    .good-btn {
      display: block;
      position: absolute;
      height: 16px;
      line-height: 12px;
      color: #f8285c;
      font-size: 13px;
      font-family: "黑體-簡";
      text-align: right;
      top: 5px;
      right: 2px;
    }
    .quan_img {
      position: absolute;
      width: 61px;
      height: 55px;
      z-index: 5;
      right: 0;
      top: 0;
      cursor: pointer;
      background: url(/assets/img/quan.png) no-repeat;
      background-size: contain;
      color: #fff;
    }
    .quan_img .num_money {
      font-family: Arial;
      font-size: 18px;
      height: 40px;
      left: 9px;
      position: absolute;
      text-align: center;
      top: 14px;
      width: 40px;
    }
  }
}

分別完成 ion-products.ts , ion-products.html , ion-products.scss祷愉,組建就創(chuàng)建完畢了螟碎。

接下來教大家如何使用組建侣夷。

2.ionic3?組建的使用

組建創(chuàng)建成功時候硝逢,可以看到默認有一個?components.module.ts的妖,?說明此component建默認是支持懶加載的矢洲。

components.modules.ts

import { IonicModule } from 'ionic-angular';
import { NgModule } from '@angular/core';
import { IonProductsComponent } from './ion-products/ion-products';

@NgModule({
    declarations: [IonProductsComponent],
    imports: [
        IonicModule
    ],
    exports: [IonProductsComponent]
})
export class ComponentsModule { }

2.1 導入component

在home.module.ts中導入components.module.ts

home.module.ts

import { ComponentsModule } from './../../components/components.module';
import { NgModule } from '@angular/core';
import { IonicPageModule } from 'ionic-angular';
import { HomePage } from './home';
@NgModule({
    declarations: [
        HomePage
    ],
    imports: [
        IonicPageModule.forChild(HomePage),ComponentsModule
    ],
})
export class HomePageModule { }

導入之后才可以在home.html中使用璧眠。

2.2 使用component

將home.html的商品列表部分換成ion-products來呈現(xiàn)

 <ion-item-divider class="t-header" color="light"> 年會禮服2017年新款 </ion-item-divider>
<ion-products [products]="products"></ion-products>

好了,試試看效果读虏。

6-2.png

至于為什么要封裝责静,封裝有什么好處,下一講用實例告訴大家盖桥。

完灾螃!

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市揩徊,隨后出現(xiàn)的幾起案子腰鬼,更是在濱河造成了極大的恐慌,老刑警劉巖塑荒,帶你破解...
    沈念sama閱讀 222,183評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件熄赡,死亡現(xiàn)場離奇詭異,居然都是意外死亡齿税,警方通過查閱死者的電腦和手機彼硫,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人乌助,你說我怎么就攤上這事溜在。” “怎么了他托?”我有些...
    開封第一講書人閱讀 168,766評論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長仆葡。 經(jīng)常有香客問我赏参,道長,這世上最難降的妖魔是什么沿盅? 我笑而不...
    開封第一講書人閱讀 59,854評論 1 299
  • 正文 為了忘掉前任把篓,我火速辦了婚禮,結(jié)果婚禮上腰涧,老公的妹妹穿的比我還像新娘韧掩。我一直安慰自己,他們只是感情好窖铡,可當我...
    茶點故事閱讀 68,871評論 6 398
  • 文/花漫 我一把揭開白布疗锐。 她就那樣靜靜地躺著,像睡著了一般费彼。 火紅的嫁衣襯著肌膚如雪滑臊。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,457評論 1 311
  • 那天箍铲,我揣著相機與錄音雇卷,去河邊找鬼。 笑死颠猴,一個胖子當著我的面吹牛关划,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播翘瓮,決...
    沈念sama閱讀 40,999評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼贮折,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了春畔?” 一聲冷哼從身側(cè)響起脱货,我...
    開封第一講書人閱讀 39,914評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎律姨,沒想到半個月后振峻,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,465評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡择份,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,543評論 3 342
  • 正文 我和宋清朗相戀三年扣孟,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片荣赶。...
    茶點故事閱讀 40,675評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡凤价,死狀恐怖鸽斟,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情利诺,我是刑警寧澤富蓄,帶...
    沈念sama閱讀 36,354評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站慢逾,受9級特大地震影響立倍,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜侣滩,卻給世界環(huán)境...
    茶點故事閱讀 42,029評論 3 335
  • 文/蒙蒙 一逸贾、第九天 我趴在偏房一處隱蔽的房頂上張望漱竖。 院中可真熱鬧投队,春花似錦哆料、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至舰攒,卻和暖如春败富,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背摩窃。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評論 1 274
  • 我被黑心中介騙來泰國打工兽叮, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人猾愿。 一個月前我還...
    沈念sama閱讀 49,091評論 3 378
  • 正文 我出身青樓鹦聪,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蒂秘。 傳聞我的和親對象是個殘疾皇子泽本,可洞房花燭夜當晚...
    茶點故事閱讀 45,685評論 2 360

推薦閱讀更多精彩內(nèi)容