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事件中,我们根据选择的项目或输入的字符数来调整输入元素的大小。

相关内容

热门资讯

透视肯定!aapoker真的假... 透视肯定!aapoker真的假的(透视)透视方法(一贯真的有挂)aapoker真的假的是一种具有地方...
透视辅助!aapoker透视怎... 透视辅助!aapoker透视怎么用(透视)透视脚本下载(确实真的是有挂)1、进入到aapoker透视...
透视玄学!aapoker如何设... 透视玄学!aapoker如何设置胜率(透视)透视脚本(确实是真的有挂);1.aapoker如何设置胜...
透视ai代打!aapoker透... 透视ai代打!aapoker透视脚本(透视)ai插件(一贯是有挂);1、任何aapoker透视脚本a...
透视神器!aapoker怎么开... 透视神器!aapoker怎么开辅助器(透视)发牌逻辑(原来有挂)在进入aapoker怎么开辅助器辅助...
透视模拟器!aapoker透视... 透视模拟器!aapoker透视脚本下载(透视)透视脚本(切实存在有挂)进入游戏-大厅左侧-新手福利-...
透视工具!aapoker辅助软... 透视工具!aapoker辅助软件合法吗(透视)透视脚本入口(总是有挂)1、打开软件启动之后找到中间准...
透视好友房!aapoker怎么... 透视好友房!aapoker怎么提高中牌率(透视)透视插件(本来是真的有挂)1、下载好aapoker怎...
透视代打!aa poker透视... 透视代打!aa poker透视软件(透视)透视脚本(其实真的是有挂)1、操作简单,无需注册,只需要使...
透视辅助!aapoker真的假... 透视辅助!aapoker真的假的(透视)辅助插件工具(竟然真的有挂);1)aapoker真的假的辅助...