Для первой функции вы можете сделать что-то вроде следующего:
Создайте файл highlight.pipe.ts со следующим кодом:
import { PipeTransform, Pipe } from '@angular/core';
@Pipe({ name: 'highlight' }) export class HighlightPipe implements PipeTransform { transform(text: string, search): string {
if (search && text) {
let pattern = search.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, '\\$&');
pattern = pattern.split(' ').filter((t) => {
return t.length > 0;
}).join('|');
const regex = new RegExp(pattern, 'gi');
return text.replace(regex, (match) => `<span class="search-highlight">${match}</span>`);
} else {
return text;
} } }
Вставьте этот канал в app.module.ts
import { HighlightPipe } from './highlight.pipe';
Обновление компонента приложения
<div class="parent">
<div>
<h5>Sample Custom Typeahead</h5>
<p>Try typing "Win" or "Mob" in input box below</p>
<input type="text" [(ngModel)]="searchByThis" (keyup)="showDropdown()">
</div>
<div>
<div (clickOutside)="closeDropDown()">
<div class='search-drop-down' *ngIf="displayDropdown">
<div (click)='selectValue(product)' class='search-results' *ngFor="let product of sampleItemDetails | searchFilter: searchByThis ">
<div [innerHTML]="product.name | highlight : searchByThis">
</div>
</div>
</div>
</div>
</div>
</div>
Не забудьте обновить свой CSS: app.component.css
:host ::ng-deep .search-highlight{
background-color: #F2E366;
}
Я уже упоминал это * суть 1016 *