首页 > 其他分享 >如何处理 Angular 单页面应用里的 a 标签,避免点击后重新加载整个应用

如何处理 Angular 单页面应用里的 a 标签,避免点击后重新加载整个应用

时间:2022-12-05 13:46:48浏览次数:77  
标签:元素 点击 应用 加载 Angular 路由 页面

问题描述

客户已经实现了一些“free html”组件,它是 HTML 的标题和包装器,与 OCC 响应一起作为内容。

<div [innerHTML]="data?.content | safeHtml"></div>

这个 HTML 里包含了 anchor element:

<div class="starItem">
   <a href="https://www.customer.com/de/jerry/c/010101">
      <div class="starImg" style="background-image:url(https://media.customer.com/medias/webmaster/homepage/images/jerry/star1.jpg);"></div>
      <p>jerry</p>
   </a>
</div>

不幸的是这个 a 标签导致页面重新加载并且不使用 Angular 路由,换言之,它会终止 SPA 的状态。

如何避免这种行为?比如实现一些侦听器并检查点击是否应该改为执行一些路由器操作并 prevent default?

解决方案

https://github.com/SAP/spartacus/pull/15317/commits

解决方案的详细实现:

  1. 在 Angular module 里,导入 RouterModule

  2. 使用 @HostListener,拦截元素的 click 事件。

当 handleClick 方法触发时,说明宿主元素已经被点击了。此时判断 event 对象的类型是否为 HTMLAnchorElement,如果是,说明确实是 a 这个元素被点击了。

然后使用 event 对象的 preventDefault 阻止 a 标签页造成的整个应用重新加载,然后使用 Angular route 的 navigate 进行页面内部跳转即可。

相关知识点

  • Event 接口的 preventDefault() 方法告诉 user agent,如果事件没有得到显式处理,则不应像通常那样执行其默认操作。在我们这个例子,即阻止 a 元素被点击后触发的页面 reload 动作。

事件继续像往常一样传播,除非它的事件侦听器之一调用 stopPropagation() 或 stopImmediatePropagation(),其中任何一个调用都会立即终止事件的传播。

  • HTMLAnchorElement: HTMLAnchorElement 接口表示超链接元素,并提供特殊的属性和方法来操纵此类元素的布局和表示。该接口对应于<a>元素。 注意不要与 <link> 混淆,后者由 HTMLLinkElement 表示。

  • route: 定义单个路由的配置对象。 一组路由收集在 Routes 数组中以定义 Router 配置。路由器尝试使用此对象中定义的配置选项将给定 URL 的段与每个路由进行匹配。本例我们使用了 router 的 navigate 方法进行单页面应用的内部导航。

标签:元素,点击,应用,加载,Angular,路由,页面
From: https://www.cnblogs.com/sap-jerry/p/16952060.html

相关文章

  • openwrt编译加载龙尚U9300模组上网
    硬件平台:MT7628Aopenwrt版本:MTK_SDK1、添加模组信息/build_dir/target-mipsel_24kc_musl/linux-ramips_mt76x8/linux-4.14.180/drivers/usb/serial/option.c在源码中找......
  • 第二章:创建你的第一个应用程序(ASP.NET Core in Action)
    本章要点创建第一个ASP.NETCoreweb应用程序运行应用程序了解应用程序的组件 读完第1章后,您应该对ASP.NETCore应用程序的工作原理以及何时使用它们有了大致的了解......
  • 使用Sencha Touch框架开发Twitter搜索应用
    目前,Android和iphone两大主流手机的应用开发吸引了大批开发人员的眼光。而开发人员最期望的是能尽可能运用旧有的技术知识,去设计这些新的应用,因此出......
  • 易基因课程回顾|表观遗传学和表观育种在品种改良中的应用研究
    大家好,这里是专注表观组学十余年,领跑多组学科研服务的易基因。 传统作物育种包括杂交、选择所需性状的遗传变异,导致遗传基础缩窄和遗传多样性缺失,从而阻碍作物改良。表......
  • 贵阳电信金阳枢纽楼能耗管理系统的设计与应用
    安科瑞陈盼摘要:建筑能耗占整个世界能耗的30%以上。提高建筑能效是缓解全球变暖、提高环境可持续发展的一种有效方法。面对严重的能源和环境问题,中国政府在建筑节能领域采取......
  • C# MD5 应用
    1.public2.{3.new4.byte[]bytes=System.Text.Encoding.UTF8.GetBytes(s);5.bytes=md5.ComputeHash(bytes);6.md5.Clear();......
  • 两道面试题,带你解析Java类加载机制
    在许多Java面试中,我们经常会看到关于Java类加载机制的考察,例如下面这道题:classGrandpa{static{System.out.println("爷爷在静态代码块");}}classFatherextendsGra......
  • jfreechart火速应用
    JAVA中的图表方面,Jfreechart是十分不错的老大了,网上有个具体的英文手册类库下载可以参考的,下面以一个投票的例子来个火速应用,简单介绍一下首先,可以将投票结果以servlet的形......
  • 批处理及有状态等应用类型在 K8S 上应该如何配置?
    众所周知,Kubernetes(K8S)更适合运行无状态应用,但是除了无状态应用.我们还会有很多其他应用类型,如:有状态应用,批处理,监控代理(每台主机上都得跑),更复杂的应用......
  • angular项目使用editor.md实现markdown编辑预览功能
    因为angular项目需要实现markdown的编辑预览功能,所以在网上查找了下资料,找到了editor.md插件来实现这个功能,经过不断踩坑,总算实现了功能需求。使用方法如下:首先我们进到......