Angular2 单选框用法

html中单选框用法如下,checked用来选中默认的单选项:

<input type="radio" name="sex" value="male" checked>Male
<input type="radio" name="sex" value="female">Female

如果使用[(ngModel)]绑定后,checked就不再生效,此时默认选中项与绑定的sex值相关,设置ngmodel绑定的sex值即可

sex:string='male'
print(text:string){
  console.log(sex);
}
<input type="radio" name="sex" [(ngModel)]="sex" value="male">Male
<input type="radio" name="sex" [(ngModel)]="sex" value="female">Female

选中某单选框后触发事件,有三种方法(可能还有更多)

1.添加(click)事件,#male和#female是ng2中的模板变量
更多关于模板变量的用法

<input type="radio" name="sex" (click)="print(male.value)" value="male" #male checked>male
<input type="radio" name="sex" (click)="print(female.value)" value="female" #female>female

2. 万能的 ngModel和ngModelChange方法,当使用ngModel时,如果用绑定的sex传值必须使用ngModelChange,因为选中单选项后,(click)执行要早于ngModelChange,所以此时(click)中传入的值还是未绑定的旧值;如果使用模板变量则不存在这个问题。

<input type="radio" name="sex" [ngModel]="sex" (ngModelChange)="sex=$event;print(sex)" value="male">Male
<input type="radio" name="sex" [ngModel]="sex" (ngModelChange)="sex=$event;print(sex)" value="female">Female

3.原生的change方法也可以

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Angular 中,你可以使用 `Renderer2` 来监听 DOM 事件,并在事件被触发时执行你的逻辑。 在子组件中,你可以在 `ngAfterViewInit` 生命周期钩子函数中获取对子元素的引用,并使用 `Renderer2` 来监听 `mousedown` 和 `mouseup` 事件。在 `mousedown` 事件中开始计时器,直到 `mouseup` 事件被触发,然后检查计时器的值是否超过了你设定的长按时间阈值,并在达到阈值时触发一个自定义事件。 在父组件中,你可以在子组件标签上使用 `(custom-event-name)` 监听该自定义事件,并在事件被触发时处理你的逻辑。 以下是一个示例代码: 子组件: ```html <template> <div #childElement> <!-- 子组件内容 --> </div> </template> ``` ```typescript import { Component, Renderer2, ElementRef, ViewChild, Output, EventEmitter } from '@angular/core'; @Component({ selector: 'app-child-component', templateUrl: './child-component.component.html', styleUrls: ['./child-component.component.css'] }) export class ChildComponentComponent { @ViewChild('childElement') childElementRef: ElementRef; @Output() longPress = new EventEmitter(); private timer: any; constructor(private renderer: Renderer2) {} ngAfterViewInit() { const childElement = this.childElementRef.nativeElement; this.renderer.listen(childElement, 'mousedown', () => { this.timer = setTimeout(() => { this.longPress.emit(); }, 1000); // 1秒钟 }); this.renderer.listen(childElement, 'mouseup', () => { clearTimeout(this.timer); }); } } ``` 父组件: ```html <app-child-component (longPress)="handleLongPress()"></app-child-component> ``` ```typescript import { Component } from '@angular/core'; @Component({ selector: 'app-parent-component', templateUrl: './parent-component.component.html', styleUrls: ['./parent-component.component.css'] }) export class ParentComponent { handleLongPress() { // 处理长按事件逻辑 } } ``` 你可以根据实际情况修改长按时间阈值和自定义事件的名称。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值