亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Angular6 用戶自定義標簽開發的實現方法

2019-11-19 12:18:46
字體:
來源:轉載
供稿:網友

2018年4月23隨著angular6 發布,我們可以看到在其官方手冊中的模板元素章節中增加了一個Element 條目(中文),通過說明我們可以知道這個功能可以幫助我們將angular以html標簽的形式嵌入到非angular的頁面環境中。下面我們就通過一個簡單的例子演示Angular6中的這一新功能。

新建angular工程

通過ng命令新建custom-tag工程

ng new custom-tag

cli新建完相應文件后會通過npm下載所信賴的包,完成后進入目錄驗證工作空間是否正常。

$cd custom-tag$ng serve --open

--open參數的作用是直接打開瀏覽器,也可以通過瀏覽器中直接輸入localhost:4200。

增加標簽功能

修改app.component.html 內容

<!--The content below is only a placeholder and can be replaced.--><!--<div style="text-align:center"> <h1>  Welcome to {{ title }}! </h1> <img width="300" alt="Angular Logo" src=""></div><h2>Here are some links to help you start: </h2><ul> <li>  <h2><a target="_blank" rel="noopener"  rel="external nofollow" >Tour of Heroes</a></h2> </li> <li>  <h2><a target="_blank" rel="noopener"  rel="external nofollow" >CLI Documentation</a></h2> </li> <li>  <h2><a target="_blank" rel="noopener"  rel="external nofollow" >Angular blog</a></h2> </li></ul>--><input #inputtext type="text" placeholder="條目"><input type="button" value="增加" (click)="addItem(inputtext.value)"><ul>  <li *ngFor="let item of items">{{item}}</li></ul>

為對應的類增加 addItem()方法,向類中的條目集合(items)增加用戶輸入的一個條目。

import { Component } from '@angular/core';@Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css']})export class AppComponent {  addItem(item:string){  console.log(`${item} to be added!`);  this.items.push(item);  } items:string[] =[];}

小結

到目前為止這是一個普通的angular應用,通過增加按鈕,要以向列表中增加元素。

應用狀態

將完成內容轉換為自定義標簽

增加@angular/comonents信賴

$ng add @angular/elements

修改app.module.ts

從包中導入相關依賴:

import { Injector} from '@angular/core';import { createCustomElement } from '@angular/elements';

將AppComponent改為動態組件,并通過createCustomElement()注冊AppComponent為custom-items

import { BrowserModule } from '@angular/platform-browser';import { NgModule,Injector } from '@angular/core';import { createCustomElement } from '@angular/elements';import { AppComponent } from './app.component';@NgModule({ declarations: [  AppComponent ], imports: [  BrowserModule ], providers: [], //bootstrap: [AppComponent] entryComponents : [  AppComponent ]})export class AppModule { constructor(private injector : Injector){  const cust_tag = createCustomElement(AppComponent, {injector : this.injector});  customElements.define('custom-items',cust_tag); } ngDoBootstrap() {} }

修改index.html頁面

<!doctype html><html lang="en"><head>  <meta charset="utf-8">  <title>CustomTag</title>  <base href="/" rel="external nofollow" >  <meta name="viewport" content="width=device-width, initial-scale=1">  <link rel="icon" type="image/x-icon" href="favicon.ico" rel="external nofollow" ></head><body>  <!--<app-root></app-root>-->  <custom-items></custom-items></body></html>

頁面重新出現在瀏覽器中了,功能也同先前一模一樣。

由于瀏覽器版本的原因可能會出現下面錯誤,無法創建自定義標簽

elements.js:384 Uncaught TypeError: Failed to construct 'HTMLElement': Please use the 'new' operator, this DOM object constructor cannot be called as a function.
    at NgElementImpl.NgElement [as constructor] (elements.js:384)
    at new NgElementImpl (elements.js:420)
    at new AppModule (app.module.ts:24)
    at _createClass (core.js:8421)
    at _createProviderInstance (core.js:8393)
    at initNgModule (core.js:8326)
    at new NgModuleRef_ (core.js:9052)
    at createNgModuleRef (core.js:9041)
    at Object.debugCreateNgModuleRef [as createNgModuleRef] (core.js:10866)
    at NgModuleFactory_.push../node_modules/@angular/core/fesm5/core.js.NgModuleFactory_.create (core.js:11583)

可以通過修改tsconfig.json中的構建目標至es6解決該問題

{ "compileOnSave": false, "compilerOptions": {  "baseUrl": "./",  "outDir": "./dist/out-tsc",  "sourceMap": true,  "declaration": false,  "moduleResolution": "node",  "emitDecoratorMetadata": true,  "experimentalDecorators": true,  "target": "es6",  "typeRoots": [   "node_modules/@types"  ],  "lib": [   "es2017",   "dom"  ] }}

增加外部事件

通過output 可以為自定義標簽增加自定義事件

import { Component,Output, EventEmitter } from '@angular/core';@Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css']})export class AppComponent {  @Output() itemAdded:EventEmitter<string> = new EventEmitter<string>(); addItem(item:string){  console.log(`${item} to be added!`);  this.items.push(item);   // 向外發送自定義事件  this.itemAdded.emit(item); } items:string[] =[];}

在客戶端頁面可以通過自定義標簽對象的addEventListener()方法增加自定義事件響應,通過 event.detail可以獲取到angular內部發送的內容

  <script>    var items = document.querySelector('custom-items');    items.addEventListener('itemAdded', (event) => {      console.log(event);    })  </script>

完結與發布

在package.json中增加發布腳本

"scripts": {    "ng": "ng",    "start": "ng serve",    "build": "ng build --prod --output-hashing none",    "test": "ng test",    "lint": "ng lint",    "e2e": "ng e2e"  },

通過npm run build 執行構建,由于我們關閉了文件名hash,得到的輸出目錄內容如下:

liunan@liunan-desktop:~/webDev/custom-tag$ ls ./dist/custom-tag/3rdpartylicenses.txt favicon.ico index.html main.js polyfills.js runtime.js scripts.js styles.css

我們可以看到輸出的index.html文件中采用如下方式引用了定義標簽的輸出,如果其他用戶使用會非常不便,

<script type="text/javascript" src="runtime.js"></script><script type="text/javascript" src="polyfills.js"></script><script type="text/javascript" src="scripts.js"></script><script type="text/javascript" src="main.js"></script>

我們可以通過使用cat命令將這些文件按照上面順序合并成一個文件

$cat runtime.js polyfills.js scripts.js main.js > custom-items.js

這樣用戶就可以引用單個文件來使用我們制做的custom-items了。

一定注記合并文件的次序,需要嚴格按照上述次序進行,否則腳本可能不能正常工作。

示例代碼

在線示例

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲人成在线一二| 国产精品国产福利国产秒拍| 亚洲天堂av在线免费| 国产精品久久久精品| 国产精品美女999| 91在线免费视频| 欧美日韩国产精品专区| 国产男人精品视频| 日本在线观看天堂男亚洲| 日韩国产欧美区| 日本高清视频精品| 国产精品美女主播在线观看纯欲| 成人黄色午夜影院| 精品国产一区二区三区在线观看| 亚洲激情成人网| 操91在线视频| 日韩av电影免费观看高清| 亚洲精品videossex少妇| 在线日韩日本国产亚洲| 91久久综合亚洲鲁鲁五月天| 在线视频欧美日韩| 国产黑人绿帽在线第一区| 国产精品福利在线观看网址| 久久久亚洲国产| 国产日韩欧美在线观看| 亚洲视频999| 欧美激情一级精品国产| 欧美日韩黄色大片| 日韩在线观看免费网站| 久久久久久国产精品三级玉女聊斋| 91中文字幕在线观看| 最近2019中文字幕大全第二页| 亚洲精品自在久久| 欧洲成人免费aa| 亚洲欧美在线免费| 国产日韩精品视频| 欧美成人sm免费视频| 中文字幕日韩欧美精品在线观看| 国产精品男女猛烈高潮激情| 在线视频欧美性高潮| 一个人www欧美| 91午夜在线播放| 久久影院模特热| 亚洲香蕉成人av网站在线观看| 欧美日韩国产一区二区三区| 热久久这里只有精品| 成人激情视频免费在线| 性视频1819p久久| 日韩网站免费观看高清| 国内精品久久久久影院优| 国产精品久久久久久久av大片| 成人黄色av网站| 亚洲综合小说区| 国产精品久久久久久久app| 久久久免费精品| 欧美在线一区二区三区四| 超在线视频97| 国产美女精品视频免费观看| 精品少妇v888av| 91精品国产乱码久久久久久蜜臀| 国外成人免费在线播放| 国产不卡在线观看| 国内精品视频在线| 日本电影亚洲天堂| 欧美综合激情网| 久久久精品影院| 久久久久久com| 久久久精品影院| 精品久久中文字幕久久av| 欧美日韩另类视频| 亚洲精品久久久久久久久久久| 国产精品免费网站| 欧美性猛交丰臀xxxxx网站| 欧美片一区二区三区| 成人午夜一级二级三级| 国产日韩欧美中文| 色婷婷av一区二区三区在线观看| 一区二区在线视频播放| 大伊人狠狠躁夜夜躁av一区| 精品美女国产在线| 国产v综合ⅴ日韩v欧美大片| 国产精品视频网址| 成人免费网站在线看| 久久精品欧美视频| 久久电影一区二区| 91精品久久久久久久久久入口| 久久伊人91精品综合网站| 美乳少妇欧美精品| 一本一本久久a久久精品牛牛影视| 亚洲娇小xxxx欧美娇小| 亚洲男人的天堂在线| 色偷偷偷亚洲综合网另类| 色噜噜国产精品视频一区二区| 97色在线播放视频| 国产精品久久久久7777婷婷| 97视频在线观看免费高清完整版在线观看| 亚洲国产精品嫩草影院久久| 久久夜精品va视频免费观看| 亚洲天堂av在线免费| 亚洲一区二区三| 国产精品爽黄69天堂a| 91久久在线视频| 国产精品丝袜白浆摸在线| 97久久精品在线| 亚洲黄色www网站| 国产综合在线观看视频| 国产69精品久久久久久| 丝袜亚洲另类欧美重口| 久久精品国产一区二区电影| 久久久噜噜噜久久中文字免| 欧美超级乱淫片喷水| 在线观看视频亚洲| 亚洲国产欧美一区二区丝袜黑人| 亚洲国产中文字幕久久网| 国产精品96久久久久久又黄又硬| 欧美综合在线观看| 中文字幕日韩av综合精品| 日韩一区二区av| 国产精品久久久久久久7电影| 国产一区二区三区在线视频| 久久久国产精品一区| 人妖精品videosex性欧美| 欧洲亚洲在线视频| 成人亚洲综合色就1024| 色综合视频一区中文字幕| 日韩欧美999| 98午夜经典影视| 久久久久久久久久久亚洲| 亚洲一级片在线看| 亚洲精美色品网站| 欧美综合一区第一页| 91国内免费在线视频| 最近的2019中文字幕免费一页| 欧美怡红院视频一区二区三区| 欧美激情成人在线视频| 国产九九精品视频| www.xxxx精品| 国产精品福利无圣光在线一区| 国产精品一区二区久久| 亚洲成在人线av| 欧美野外wwwxxx| 欧美成人h版在线观看| 国产精品视频资源| 91免费的视频在线播放| 国产精品揄拍一区二区| 亚洲人av在线影院| 韩曰欧美视频免费观看| 91亚洲精品久久久| 7777免费精品视频| 亚洲va欧美va国产综合久久| 国产综合香蕉五月婷在线| 精品五月天久久| 亚洲精品免费在线视频| 九九精品在线播放| 欧美另类暴力丝袜| 97久久超碰福利国产精品…| 久久99热这里只有精品国产| 成人黄色在线观看| 高跟丝袜欧美一区| 欧美一区二区三区四区在线| 美女视频久久黄| 欧美视频13p| 亚洲色图第三页| 91亚洲精品久久久久久久久久久久|