Angular输入自动大小与typeahead不起作用
创始人
2024-10-29 15:00:57
0

使用ngAfterViewInit和setTimeout函数来延迟自动大小初始化

在Angular中,当使用Typeahead控件时,自动跟踪控件的大小可能会出现问题。这是因为Typeahead创建了一个动态内容,可能在组件的生命周期钩子函数ngOnInit或ngAfterViewInit结束后再加载。当Angular尝试为不稳定的元素计算自动大小时,它会返回错误的结果。

为了解决这个问题,我们可以使用ngAfterViewInit和setTimeout函数来延迟自动大小初始化,等到Typeahead控件完全加载后再计算。下面是示例代码:

import { Component, ElementRef, ViewChild } from '@angular/core';

@Component({ selector: 'app-typeahead-example', template: }) export class TypeaheadExampleComponent { @ViewChild('inputElement', { static: true }) inputElement: ElementRef;

selectedItem: string; dataSource = ['Apple', 'Banana', 'Cherry', 'Durian'];

ngAfterViewInit() { setTimeout(() => { this.inputElement.nativeElement.setAttribute('size', this.selectedItem.length + 2); }, 100); }

onChange(event) { if (event && event.length) { this.inputElement.nativeElement.setAttribute('size', event.length + 2); } else { this.inputElement.nativeElement.removeAttribute('size'); } } }

在上面的示例中,我们通过ViewChild装饰器获取了输入元素的引用,并在ngAfterViewInit钩子函数中使用setTimeout函数来延迟自动大小的初始化。在onChange事件中,我们根据选择的项目或输入的字符数来调整输入元素的大小。

相关内容

热门资讯

技术分享"微信小程序... 【亲,微信小程序微乐房间怎么开挂 这款游戏可以开挂的,确实是有挂的,很多玩家在这款微信小程序微乐房间...
透视辅助“宝宝浙江游戏脚本”开... 您好:宝宝浙江游戏脚本这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌...
一分钟教你"掌酷天天... 一分钟教你"掌酷天天开心辅助器"开挂(下载)辅助下载有挂方法-必备教程;无需打开直接搜索加薇1367...
十分钟辅助“免费闲逸辅助器(免... 免费闲逸辅助器(免费) 无需打开直接搜索微信:136704302本司针对手游进行,选择我们的四大理由...
玩家攻略推荐"陕西三... 玩家攻略推荐"陕西三代实战技巧"开挂(下载)辅助下载有挂实锤-总结教程 【无需打开直接搜索加薇136...
来一盘"牛魔辅助&q... 来一盘"牛魔辅助"开挂(平台)辅助平台有挂教学-透明挂教程;无需打开直接搜索加薇136704302(...
透视挂"边锋斗地主辅... 透视挂"边锋斗地主辅助微信"开挂(安装)辅助安装有挂猫腻-专业教程>>您好:软件加薇13670430...
必看攻略"微乐小程序... 必看攻略"微乐小程序辅助器脚本"开挂(插件)辅助插件有挂技术-德州论坛【无需打开直接搜索加薇1367...
一起来讨论"卡五星辅... 一起来讨论"卡五星辅助器逍遥"开挂(安装)辅助安装有挂猫腻-揭秘教程;无需打开直接搜索薇:13670...
最新通报"手机挂机软... 大家好,今天小编来为大家解答手机挂机软件这个问题咨询软件客服可以免费测试直接加微信(13670430...