亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Angular 實(shí)現(xiàn)輸入框中顯示文章標(biāo)簽的實(shí)例代碼

 更新時(shí)間:2018年11月07日 14:09:37   作者:HybridSuns  
這篇文章主要介紹了Angular 實(shí)現(xiàn)輸入框中顯示文章標(biāo)簽的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

很多網(wǎng)站發(fā)帖的時(shí)候標(biāo)簽輸入框看起來像是在 <input> 元素中直接顯示標(biāo)簽. 比如這種

一開始以為是把 <span> 放在 <input> 中, 看了下 Stack Overflow 和 SegmentFault 的實(shí)現(xiàn)方式, 原來是用一個(gè) <div> 把 <span> 和 <input> 包起來, 然后讓 <div> 模仿出輸入框的樣式. 再給 <div> 加上eventListensor, 點(diǎn)擊 <div> 時(shí), 使 <input> 獲得焦點(diǎn).

StackBlitz 上的 Demo

在 Angular 中的實(shí)現(xiàn)

將各個(gè)tag用 <span> 顯示, 在同一行放一個(gè) <input> 用來輸入新的標(biāo)簽, 然后用一個(gè) <div> 將它們包起來

<div>
 <span *ngFor="let tag of tags">{{tag}}</span>
 <input type="text">
</div>

之后給 <div> 加上一個(gè)事件監(jiān)聽器, 點(diǎn)擊 <div> 的時(shí)候, 激活 <input> . 為了能夠獲取 <input> 元素, 使用 Angular的 Template reference variables 來命名 <input> .

<div (click)="focusTagInput()">
 <span *ngFor="let tag of tags">{{tag}}</span>
 <input #tagInput type="text">
</div>

在component中獲得 <input> 元素

export class EditorComponent {
 // 用 @ViewChild 獲得 DOM 元素
 @ViewChild('tagInput') tagInputRef: ElementRef;

 focusTagInput(): void {
  // 讓 input 元素獲得焦點(diǎn)
  this.tagInputRef.nativeElement.focus();
 }
}

到此基本上整體思路就實(shí)現(xiàn)了. 接下來就是完善一下細(xì)節(jié). 比如

輸入完一個(gè)標(biāo)簽后, 按逗號或者空格自動(dòng)將輸入的標(biāo)簽添加到前面的標(biāo)簽列表中
給標(biāo)簽加上一個(gè)刪除按鈕

當(dāng)輸入框是空的時(shí)候, 按鍵盤的退格鍵可以刪除標(biāo)簽列表中最后一個(gè)標(biāo)簽
我們一步一步來.

自動(dòng)將標(biāo)簽加入標(biāo)簽列表

給 <input> 元素添加一個(gè)事件監(jiān)聽, 可以監(jiān)聽鍵盤按下了哪個(gè)鍵. 和鍵盤按鍵有關(guān)的事件有 keydown , keypress , keyup .

根據(jù) MDN 上的解釋, keydown 和 keypress 都是在按鍵按下之后觸發(fā), 不同點(diǎn)在于, 所有按鍵都可以觸發(fā) keydown , 而 keypress 只有按下能產(chǎn)生字符的鍵時(shí)才觸發(fā), shift , alt 這些按鍵不會(huì)觸發(fā) keypress . 而且 keypress 從 DOM L3 之后就棄用了.

keyup 就是松開按鍵的時(shí)候觸發(fā).

首先給 <input> 標(biāo)簽添加事件監(jiān)聽 (這里用的 keyup , 后面會(huì)解釋為什么不用 keydown ).

<input #tagInput type="text" (keyup)="onKeyup($event)">

component 中對接收到的 KeyboardEvent 進(jìn)行處理

onKeyup(event: KeyboardEvent): void {
 // 這里將標(biāo)簽輸入框作為 FormGroup 中的一個(gè) control
 const inputValue: string = this.form.controls.tag.value;

 // 檢查鍵盤是否按下了逗號或者空格, 而且得要求
 if (event.code === 'Comma' || event.code === 'Space') {
  this.addTag(inputValue);
  // 將新輸入的標(biāo)簽加入標(biāo)簽列表后, 把輸入框清空
  this.form.controls.tag.setValue('');
 }
}

addTag(tag: string): void {
 // 去掉末尾的逗號或者空格
 if (tag[tag.length - 1] === ',' || tag[tag.length - 1] === ' ') {
  tag = tag.slice(0, -1);
 }
 // 有可能什么也沒輸入就直接按了逗號或者空格, 如果已經(jīng)在列表中, 也不添加
 // 這里使用了 lodah 的 find
 if (tag.length > 0 && !find(this.tags, tag)) {
  this.tags.push(tag);
 }
}

使用 keyup 而不是 keypress 的原因:

一開始我是用的 keypress , 但是 keypress 觸發(fā)的時(shí)候, <input> 還沒接收到按鍵的值, 所以就會(huì)出現(xiàn)標(biāo)簽添加到列表, 并且清空輸入框后, 輸入框才接收到按下的逗號, 于是剛剛清空的輸入框中就出現(xiàn)了一個(gè)逗號.

keyup 是在釋放按鍵之后才觸發(fā), 此時(shí)輸入框已經(jīng)接收到按下的逗號的值, 再清空輸入框的時(shí)候就能把逗號一起清除掉

給標(biāo)簽加上一個(gè)刪除按鈕

就在每個(gè)標(biāo)簽旁邊添加一個(gè)叉號 × , 點(diǎn)擊的時(shí)候, 把標(biāo)簽從列表中移除就行了

<div (click)="focusTagInput()">
 <span *ngFor="let tag of tags">
  {{tag}}
 <span (click)="removeTag(tag)">×</span>
 </span>
 <input #tagInput type="text" (keyup)="onKeyup($event)">
</div>
removeTag(tag: string): void {
 this.tags.splice(-1);
}

按下退格鍵刪除最后一個(gè)標(biāo)簽

不需要給DOM添加別的事件監(jiān)聽, 只需要對component中的方法稍加修改即可

onKeyUp(event: KeyboardEvent): void {
 const inputValue: string = this.form.controls.tag.value;
 // 按下退格鍵, 且輸入框是空的時(shí)候, 刪除最后一個(gè)標(biāo)簽
 if (event.code === 'Backspace' && !inputValue) {
  this.removeTag();
  return;
 } else {
  if (event.code === 'Comma' || event.code === 'Space') {
   this.addTag(inputValue);
   this.form.controls.tag.setValue('');
  }
 }
}

// 修改參數(shù)為可選參數(shù), 當(dāng)沒有參數(shù)時(shí), 刪除列表中最后一個(gè),
// 有參數(shù)時(shí), 刪除傳入的標(biāo)簽
removeTag(tag?: string): void {
 if (!!tag) {
  // 這里使用了 lodash 的 pull
  pull(this.tags, tag);
 } else {
  this.tags.splice(-1);
 }
}

接下來就是調(diào)整樣式了. 就略過了

不足之處

  • 使用中文輸入法輸入完一個(gè)詞按下空格時(shí), 會(huì)直接把輸入的內(nèi)容加到列表里
  • 使用中文輸入法時(shí), 按下退格鍵, 如果輸入框里沒有別的內(nèi)容, 會(huì)直接刪除列表中最后一個(gè)標(biāo)簽

總結(jié)

以上所述是小編給大家介紹的Angular 實(shí)現(xiàn)輸入框中顯示文章標(biāo)簽的實(shí)例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • AngularJS日程表案例詳解

    AngularJS日程表案例詳解

    本文通過實(shí)例代碼給大家介紹了AngularJS日程表案例詳解,通過簡單代碼實(shí)現(xiàn)了添加事件/完成事件/刪除事件功能,具體代碼大家參考下本文
    2017-08-08
  • angular 實(shí)現(xiàn)下拉列表組件的示例代碼

    angular 實(shí)現(xiàn)下拉列表組件的示例代碼

    這篇文章主要介紹了angular 實(shí)現(xiàn)下拉列表組件的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • Angular HMR(熱模塊替換)功能實(shí)現(xiàn)方法

    Angular HMR(熱模塊替換)功能實(shí)現(xiàn)方法

    本篇文章主要介紹了Angular HMR(熱模塊替換)功能實(shí)現(xiàn)方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-04-04
  • angularjs 處理多個(gè)異步請求方法匯總

    angularjs 處理多個(gè)異步請求方法匯總

    這篇文章主要介紹了angularjs 處理多個(gè)異步請求方法匯總,需要的朋友可以參考下
    2015-01-01
  • AngularJS中的Promise詳細(xì)介紹及實(shí)例代碼

    AngularJS中的Promise詳細(xì)介紹及實(shí)例代碼

    這篇文章主要介紹了AngularJS中的Promise詳細(xì)介紹及實(shí)例代碼的相關(guān)資料,Promise是一種模式,以同步操作的流程形式來操作異步事件,避免了層層嵌套,可以鏈?zhǔn)讲僮鳟惒绞录?,需要的朋友可以參考?/div> 2016-12-12
  • angularjs客戶端實(shí)現(xiàn)壓縮圖片文件并上傳實(shí)例

    angularjs客戶端實(shí)現(xiàn)壓縮圖片文件并上傳實(shí)例

    這篇文章主要介紹了angularjs客戶端實(shí)現(xiàn)壓縮圖片文件并上傳實(shí)例,本文直接給出代碼實(shí)例,需要的朋友可以參考下
    2015-07-07
  • 詳解Angualr 組件間通信

    詳解Angualr 組件間通信

    本篇文章主要介紹了Angualr 組件間通信,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-01-01
  • Angular使用$http.jsonp發(fā)送跨站請求的方法

    Angular使用$http.jsonp發(fā)送跨站請求的方法

    這篇文章主要介紹了Angular使用$http.jsonp發(fā)送跨站請求的方法,結(jié)合實(shí)例形式分析了$http.jsonp發(fā)送跨站請求遇到的問題與相應(yīng)的解決方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2017-03-03
  • AngularJS入門教程之Cookies讀寫操作示例

    AngularJS入門教程之Cookies讀寫操作示例

    這篇文章主要介紹了AngularJS的Cookies讀寫操作,結(jié)合實(shí)例形式分析了ngCookies模塊與get和put方法進(jìn)行cookie讀寫操作的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2016-11-11
  • Angular實(shí)現(xiàn)較為復(fù)雜的表格過濾,刪除功能示例

    Angular實(shí)現(xiàn)較為復(fù)雜的表格過濾,刪除功能示例

    這篇文章主要介紹了Angular實(shí)現(xiàn)較為復(fù)雜的表格過濾,刪除功能,結(jié)合實(shí)例形式分析了AngularJS針對表格的排序、查詢匹配、頁面元素屬性動(dòng)態(tài)修改等相關(guān)操作技巧,需要的朋友可以參考下
    2017-12-12

最新評論