码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 如何处理 Angular 单页面应用里的 a 标签,避免点击后重新加载整个应用


    问题描述

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

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

    这个 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>jerryp>
       a>
    div>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    不幸的是这个 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 接口表示超链接元素,并提供特殊的属性和方法来操纵此类元素的布局和表示。该接口对应于元素。 注意不要与 混淆,后者由 HTMLLinkElement 表示。

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

  • 相关阅读:
    2.2 PE结构:文件头详细解析
    y109.第六章 微服务、服务网格及Envoy实战 -- 可观测应用之分布式跟踪(二十)
    麻辣烫有几种类型?不同种麻辣烫怎么做
    大厂设计师力推的14款平面图设计工具!
    notepad++进行UTF-16编码的时候前面出现FFFE
    海量电商数据与用友YS系统数据对接案例
    关于区间操作查找(前缀和与差分)+树状数组基础
    干货 | 深度多元时序模型在携程关键指标预测场景下的探索应用
    基于Matlab通过惯性传感器融合估计方向(附源码)
    8.云原生-Kubesphere3.3.0使用DevOps部署RuoYi 微服务版(下篇)
  • 原文地址:https://blog.csdn.net/i042416/article/details/128111755
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号