当前位置: 首页 > news >正文

vue 判断字符串开头是http或者https

在 Vue 中判断字符串是否以 httphttps 开头,可以通过以下步骤实现:

方法一:使用 startsWith() 方法

// 在 Vue 组件的方法或计算属性中
isExternalLink(url) {
  return url?.startsWith('http://') || url?.startsWith('https://');
}

方法二:使用正则表达式(推荐)

isExternalLink(url) {
  return /^https?:\/\//i.test(url || '');
}

说明:

  • ^https?:\/\/ 匹配以 http://https:// 开头的字符串。
  • i 表示不区分大小写(如 HTTP:// 也会被匹配)。
  • 使用可选链操作符 ?. 和默认空字符串防止 urlnullundefined 时报错。

在 Vue 模板中使用

<template>
  <a :href="url" :target="isExternalLink(url) ? '_blank' : '_self'">链接</a>
</template>

<script>
export default {
  data() {
    return {
      url: 'https://example.com'
    }
  },
  methods: {
    isExternalLink(url) {
      return /^https?:\/\//i.test(url || '');
    }
  }
}
</script>

处理边缘情况

  1. 空值处理:如果 url 可能为空,使用 url || '' 确保传入的是字符串。
  2. 协议相对 URL:若需排除 //example.com 这种形式,正则表达式保持不变即可,因为它只匹配明确带有 httphttps 的情况。

示例:动态绑定图片路径

<template>
  <img :src="fullImageUrl" alt="示例图片">
</template>

<script>
export default {
  data() {
    return {
      imageUrl: 'user-uploaded/image.jpg',
      basePath: 'https://cdn.example.com/'
    }
  },
  computed: {
    fullImageUrl() {
      return this.isExternalLink(this.imageUrl) 
        ? this.imageUrl 
        : `${this.basePath}${this.imageUrl}`;
    }
  },
  methods: {
    isExternalLink(url) {
      return /^https?:\/\//i.test(url || '');
    }
  }
}
</script>

关键点总结:

  • 正则效率:正则表达式更简洁且能直接处理大小写问题。
  • 防御性代码:处理可能的空值,避免运行时错误。
  • 逻辑复用:将判断逻辑封装成方法或计算属性,提高代码复用性。

相关文章:

  • 2025-2-17算法打卡
  • 使用神经网络对驾驶数据进行道路类型分类
  • 《RCooper: 一个真实世界的大规模道路边协同感知数据集》学习笔记
  • C#异步/多线程编程中Task对象强大的功能介绍。
  • 三、tsp学习笔记——屏幕移植
  • UDP与TCP
  • Qt——连接MySQL数据库之ODBC的方法详细总结(各版本大同小异,看这一篇就够了)
  • Python常见面试题的详解10
  • STM32 串口转 虚拟串口---实现USB转串口功能
  • Git高级用法
  • MySQL-事务隔离级别
  • FTP自动上传/vue打包自动上传
  • Redis(高阶篇)02章——BigKey
  • 【私人笔记】Web前端
  • 计算机网络(涵盖OSI,TCP/IP,交换机,路由器,局域网)
  • python旅游推荐系统+爬虫+可视化(协同过滤算法)
  • ES7 (ES2016) 新特性
  • try learning-git-branching
  • 机器学习_14 随机森林知识点总结
  • 【Python 打造高效文件分类工具】
  • 网站后台ftp账户/抖音竞价推广怎么做
  • 云南电商网站建设/象山seo外包服务优化
  • 杭州做网站五/营销推广投放平台
  • 万全县城乡建设网站/google play store
  • 新化 网站开发/网站制作报价
  • 网站建设推广销售好做吗/武汉网站建设