在Vue组件之间传值后阻止a链接跳转的方法

本文介绍了在Vue应用中处理组件间传值后如何阻止a链接默认跳转的行为。针对该问题,提出了两种解决方案:一是通过子组件监听父组件传递的值,动态修改DOM中a链接的onclick事件,使其返回false;二是通过watch方法遍历内容字符串,改变a链接的href属性或替换为其他标签。
摘要由CSDN通过智能技术生成

公司有一个特定场景:点击新闻列表中的某一项,然后在弹出框内展示新闻详情。即:新闻列表为父组件,弹框为子组件。内容详情以传值的方式给到子组件。但是内容中有很多a标签,点击后会直接跳转。业务逻辑需要阻止跳转使a链接失效

 

第一种方法: 在子组件内监听父组件传递过来的值。手动修改dom元素将a链接的onclick事件return flase


<template>
	<div class="c-s-box">
		<div class="c-s-title">新闻详情</div>
		<div class="c-d-content">
			<p class="new-c-title" v-text="propsObj.title"></p>
			<p class="new-c-summary" v-text="propsObj.summary"></p>
			<p class="new-c-content" v-html="propsObj.htmlContent"></p>
		</div>

	</div>
</template>

<script>
	import Vue from 'vue'
	
	export default {
		data() {
			return {

			}
		},
		methods: {
			preventAclick(){
				let aTagBox = window.document.getElementsByClassName("new-c-content")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值