欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

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

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

StackBlitz 上的 Demo

在 Angular 中的實現(xiàn)

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

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

之后給 <div> 加上一個事件監(jiān)聽器, 點擊 <div> 的時候, 激活 <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 元素獲得焦點
  this.tagInputRef.nativeElement.focus();
 }
}

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

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

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

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

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

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

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

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

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

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

onKeyup(event: KeyboardEvent): void {
 // 這里將標(biāo)簽輸入框作為 FormGroup 中的一個 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ā)的時候, <input> 還沒接收到按鍵的值, 所以就會出現(xiàn)標(biāo)簽添加到列表, 并且清空輸入框后, 輸入框才接收到按下的逗號, 于是剛剛清空的輸入框中就出現(xiàn)了一個逗號.

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

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

就在每個標(biāo)簽旁邊添加一個叉號 × , 點擊的時候, 把標(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);
}

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

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

onKeyUp(event: KeyboardEvent): void {
 const inputValue: string = this.form.controls.tag.value;
 // 按下退格鍵, 且輸入框是空的時候, 刪除最后一個標(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ù)時, 刪除傳入的標(biāo)簽
removeTag(tag?: string): void {
 if (!!tag) {
  // 這里使用了 lodash 的 pull
  pull(this.tags, tag);
 } else {
  this.tags.splice(-1);
 }
}

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

不足之處

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

總結(jié)

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

相關(guān)文章

  • AngularJS日程表案例詳解

    AngularJS日程表案例詳解

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

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

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

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

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

    angularjs 處理多個異步請求方法匯總

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

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

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

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

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

    詳解Angualr 組件間通信

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

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

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

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

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

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

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

最新評論