首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在angular 6中,Onclick事件在动态html字符串中不起作用

在Angular 6中,如果在动态HTML字符串中使用Onclick事件,可能会导致事件无法正常触发。这是因为Angular的事件绑定机制是基于模板语法的,而动态HTML字符串不会被Angular的编译器处理。

为了解决这个问题,可以使用Angular提供的事件绑定语法来替代Onclick事件。具体步骤如下:

  1. 在组件的模板文件中,使用属性绑定语法将点击事件绑定到一个组件中的方法。例如,假设有一个名为"handleClick"的方法:
代码语言:txt
复制
<button (click)="handleClick()">Click me</button>
  1. 在组件的类文件中,定义"handleClick"方法来处理点击事件:
代码语言:txt
复制
handleClick() {
  // 处理点击事件的逻辑
}
  1. 在动态HTML字符串中,使用属性绑定语法来绑定点击事件。例如:
代码语言:txt
复制
const dynamicHtml = `<button (click)="handleClick()">Click me</button>`;

需要注意的是,动态HTML字符串中的属性绑定语法必须使用双引号,而不是单引号。

关于Angular的事件绑定和模板语法的更多信息,可以参考腾讯云的Angular文档:Angular事件绑定

请注意,以上答案仅针对Angular 6中Onclick事件在动态HTML字符串中不起作用的情况,具体解决方法可能因版本而异。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Angular动态创建元素的一些坑

在html文件中 用ngFor 动态生成子html 元素的自定义属性,比如data-title ,发现angular报错,不让用 。解决办法:采用 attr.自定义属性名 即可 ?...实现拖拽功能 需要复制html元素 append到其他元素时 希望将原始html标签上的 (click) 事件属性也一起复制,发现angular会自动将(click) 删除 ,无奈需要在ts里动态添加click...或者直接对对象的onclick属性 绑定方法 ,此种做法可以使用父级this上的方法 ?...angular在页面渲染时会为html元素自动增加属性 _ngcontent-c[数字] ,angular的某些class样式和这类属性密切耦合影响页面样式 ;而在ts代码中动态复制html标签时该属性还没有生成...,动态复制的html元素不会被再次渲染生成 _ngcontent-c[数字] 属性,因此复制的html与原始的html样式无法一致 。

2.5K20
  • React学习(四)-理清React的工作方式

    至少在没有出现React,vue,Angular等这些框架之前,它仍然是霸主统治性地位存在的,然而现在真的不得不说,它的确是在走向落寞....React的工作方式及优点 在没有组件化React,Vue,Angular之前,毫无疑问,JQ是最直观易懂的,但是当项目逐渐变得复杂庞大时,用JQ写出来的代码耦合度就没那么高了的,正是这样,也就诞生了一些...它只会修改数据变化的的DOM部分,并不需要去关心怎么去操作DOM 如下图所示 在React中,对JSX元素上添加事件,是通过on*EventType 这种内联方式添加的,不需要手动调用浏览器原生的 addEventListener...进行事件监听,在React中,它已经帮我们封装好了一些事件类型属性(onClick,onChange,onFocus,obBlur等) 当需要给某个JSX元素监听事件的时候,只需要通过内联方式,在React...也就是说, onClick={…} /> 这样的写法是不起作用的 如果想要在组件标签上监听事件起作用,也可以做到,就是结合第三方模块styled-components样式组件进行使用,是可以做到的

    1.8K30

    浅谈Angular

    就算DOM属性和HTML属性名字一样,那也不是同一个东西) 3.事件绑定 ()--如果想要获取事件对象,传入$event 例:中移除 *ngFor--动态创建DOM结构 ngSwitch--通过匹配case...从Observable的中文名:”可观察的”就能看出,Observable的作用是可以起到类似监听的作用,但它的监听往往都是在跨页面中, 6.组件间通信: 1.父向子 -- @Input装饰器声明输入属性...,要声明在子组件里 2.子向父 -- @Output装饰器声明事件,要声明在子组件里 3.兄弟之间 -- 中间人模式 拓展:事件源对象 在事件中,当前操作的那个元素就是事件源。...比如网页元素中a标签和input都有onclick事件,当点击a发生onclick事件时,事件源就是a标签,当点击input发送onclic事件是,事件源就是input。

    4.4K10

    React基础(4)-理清React的工作方式

    至少在没有出现React,vue,Angular等这些框架之前,它仍然是霸主统治性地位存在的,然而现在真的不得不说,它的确是在走向落寞....React的工作方式及优点 在没有组件化React,Vue,Angular之前,毫无疑问,JQ是最直观易懂的,但是当项目逐渐变得复杂庞大时,用JQ写出来的代码耦合度就没那么高了的,正是这样,也就诞生了一些...它只会修改数据变化的的DOM部分,并不需要去关心怎么去操作DOM 如下图所示 在React中,对JSX元素上添加事件,是通过on*EventType 这种内联方式添加的,不需要手动调用浏览器原生的 addEventListener...进行事件监听,在React中,它已经帮我们封装好了一些事件类型属性,当需要给某个元素监听事件的时候,只需要通过内联方式,React元素上加on*EventType就可以了,注意这里事件类型的写法,驼峰式命名法...也就是说,onClick={…} /> 这样的写法是不起作用的 如果想要做到这一点,在组件标签上监听事件起作用,也可以做到,就是结合第三方模块styled-components样式组件进行使用

    2.1K20

    每个前端开发者都可以开发一个属于自己的库或框架「Strve.js生态初步建成」

    我当时在想,如果我仅仅想在JS中写HTML标签,那么使用JS中的模板字符串就已经具备在字符串内写HTML标签的能力了,为什么不换一下思路,研究一下在模板字符串中写HTML标签这种更加方便直接的方案呢?...刚开始我就是从基础着手,写一串字符串,然后怎么想办法将字符串挂载到页面中。借鉴了React、Vue这些框架的思想,在页面指定一个挂载元素。...比如说,你可以在模板字符串中直接可以写HTML标签。...在Strve.js中,你可以尽情的使用JavaScript 的模板字符串,感受它独特的魅力吧!...我们可以使用原生onclick指令来监听 DOM 事件,并在触发事件时执行一些 JavaScript。

    94840

    AngularDart4.0 指南- 模板语法一 顶

    在Angular中,组件扮演控制器/视图模型的一部分,模板表示视图。 内容 本指南涵盖了Angular模板语法的基本元素,以及构建视图所需的元素: 模板中的HTML 插值({{...}})...您可以使用组件和指令出现的新元素和属性来扩展模板的HTML词汇表。 在下面的章节中,您将学习如何通过数据绑定来动态获取和设置DOM(文档对象模型)值。...在事件循环的一个回合期间,依赖值不应该改变。如果一个幂等表达式返回一个字符串或一个数字,当它在一行中调用两次时会返回相同的字符串或数字。...但是它也与你习惯的HTML有很大的不同。 它需要一个新的心智模式。 在HTML开发的正常过程中,您可以使用HTML元素创建一个可视结构,并通过使用字符串常量设置元素属性来修改这些元素。...当你写数据绑定时,你只处理目标对象的属性(properties)和事件(events)。 HTML属性(attributes)不起作用。 记住这个模型,继续阅读以了解绑定目标。

    5.2K10

    【玩转腾讯云】手把手教你使用VueReactAngular三大框架开发Pagination分页组件

    需要注意⚠️的是在React中HTML元素的class需要写成className,原因是class是JavaScript中的保留关键字,而React使用的JSX是JavaScript的扩展,使用class...内部状态中还定义了一个dataList字段,用于动态传入给List组件,达到分页的效果。...created生命周期事件在Vue实例初始化之后,挂载到DOM之前执行,在created事件中我们将第1页的数据赋值给dataList: created() { this.setList(this.defaultCurrent...onChange事件是Pagination组件的页码改变事件,当点击上一个/下一页翻页按钮时执行,在该事件中可获取到当前的页码current。...由于Pager中的当前页码有可能通过外部改变(比如上一页/下一页按钮),因为在传入的defaultCurrent变化时,需要动态改变current,这需要借助另一个React Hook——useEffect

    7.8K00

    走进AngularJs(二) ng模板中常用指令的使用方式

    通过使用模板,我们可以把model和controller中的数据组装起来呈现给浏览器,还可以通过数据绑定,实时更新视图,让我们的页面变成动态的。ng的模板真是让我爱不释手。...($event){ alert($event.target); //…………………… }   在模板中可以用变量$event将事件对象传递到controller中。...我也一样对此表示不解,因为不写onclick已经很多年。。。...文件并解析为DOM;   2) 浏览器加载angular.js文件;   3) angular监听DOMContentLoaded 事件,监听到时开始启动;   4) angular寻找ng-app指令...因为我编写的是单页面应用,页面只会在加载index.html的时候出这个问题,只需在index.html中的模板中换成ng-bind就行。其他的模板是我们动态加载的,就可以放心使用{{}}了。

    3K20

    AngularDart4.0 指南- 用户输入 顶

    \$EVENT Dart文件中的非原始字符串需要$前面的\。 如果模板位于HTML文件中,请使用$ event而不是\ $event。...当用户按下并释放一个键时,会发生一个键盘事件,而Angular在$ event变量中提供一个相应的DOM事件对象,该代码将该代码作为参数传递给组件的onKey()方法。...以下示例使用模板引用变量在简单模板中实现按键回送。...在输入框中输入内容,然后观看每个按键显示更新。 ? 除非你绑定一个事件,否则这根本不起作用。 Angular仅在应用程序响应异步事件(如击键)时才更新绑定(以及屏幕)。...本页展示了事件绑定技术。 现在,把它放在一个微型应用程序,可以显示英雄列表,并添加新的英雄列表。 用户可以通过在输入框中输入英雄的名字并点击添加来添加英雄。 ? 下面是“英雄之旅”组件。

    3.5K00

    angularjs中常用的ng指令介绍【转载】

    也可以在标记中使用表达式,如{{1+2}},或者与过滤器一起使用{{1+2 | currency}}。在框架内部,字符串不会简单的使用eval()来执行,而是有一个专门的$parse服务来处理。...){ alert($event.target); //…………………… } 在模板中可以用变量$event将事件对象传递到controller中。...我也一样对此表示不解,因为不写onclick已经很多年。。。...DOM; 2) 浏览器加载angular.js文件; 3) angular监听 DOMContentLoaded  事件,监听到时开始启动; 4) angular寻找ng-app指令,确定作用范围; 5...因为我编写的是单页面应用,页面只会在加载index.html的时候出这个问题,只需在index.html中的模板中换成ng-bind就行。其他的模板是我们动态加载的,就可以放心使用{{}}了。

    1.9K30

    Angular 6.x 基础教程

    第三节 - 事件和模板引用 在 Angular 中,我们可以使用 (eventName) 语法,进行事件绑定。此外,可以使用 #variableName 的语法,定义模板引用。...第四节 - 事件进阶 获取鼠标事件 在第三节的示例中,假如我们需要获取鼠标事件,那应该怎么办呢?...)">点击 当 Angular 在调用我们的事件处理函数时,会自动帮我们处理调用的参数。...第十节 - 组件样式 在 Angular 中,我们可以在设置组件元数据时通过 styles 或 styleUrls 属性,来设置组件的内联样式和外联样式。...用过 AngularJS 1.x 的同学,对 ng-class 应该很熟悉,通过它我们能够根据条件,为元素动态的添加或移除对应的样式。在 Angular 中,对应的指令是 ngClass 。

    15.6K20

    angular基础面试题_java web面试题

    CurrencyPipe :把数字转换成货币字符串,根据本地环境中的规则进行格式化。 DecimalPipe:把数字转换成带小数点的字符串,根据本地环境中的规则进行格式化。...PercentPipe :把数字转换成百分比字符串,根据本地环境中的规则进行格式化angualr angular路由配置: 路由配置在 app.route.ts 中 路由跳转方式 [routerLink...,在ngDoCheck之后 ngAfterContentChecked:每当 Angular 检查完被投影到组件或指令中的内容之后调用,在ngAfter...之后调用 ngAfterViewInit:当...灵活的路由,具备延迟加载功能 更容易学习 angular1是全局监听,变量越多性能越差,angular2采用模块化监听,提升了性能 在Angular 2应用中,我们应该注意哪些安全威胁?...就像任何其他客户端或Web应用程序一样,Angular 2应用程序也应该遵循一些基本准则来减轻安全风险。其中一些是: 避免为你的组件使用/注入动态HTML内容。

    13K50

    ionic3应该善用组件和指令

    angular4提供了很多功能强大的内置指令,但在现实情况中,这些内置指令可能还不能完全满足实际要求,这时我们就需要编写自定义指令来实现特定要求。...在angular1时代,组件和指令是一回事,即严格来说,没有组件这概念,只有指令,而到了angular2时代,虽说组件仍是一种特殊的指令,但已经有一定目的明显区分开来,分别用Directive和Component...我们在组件html里就可以这样调用了: test ?...指令效果.png 5)指令扩展,支持事件操作 我们增加一个点击事件响应操作,点击时,循环切换背景色。...里引入后,在html如下调用即可: 总结:可以看出来,自定义指令和组件不算复杂

    3.5K40

    AngularDart4.0 指南- 模板语法二 顶

    在以下示例中,目标是按钮的单击事件。...如果名称未能匹配已知指令的元素事件或输出属性,则Angular会报告“未知指令”错误。 $event和事件处理语句 在事件绑定中,Angular为目标事件设置了一个事件处理程序。...事件发生时,处理程序执行模板语句。 模板语句通常包含一个接收器,它响应事件执行一个动作,例如将HTML控件的值存储到模型中。...NgStyle:添加和删除一组HTML样式。 NgModel:双向数据绑定到HTML表单元素。 NgClass 您通常通过动态添加和删除CSS类来控制元素的显示方式。...字符串“let hero of heroes”是指: 取英雄列表中的每个英雄,将其存储在本地英雄循环变量中,并使其可用于每次迭代的模板HTML。

    30K20
    领券