校验电话号码自动生成标签(包含多个粘体复制生成标签)

简介: 对电话号码进行校验,并且自动生成小标签。

校验电话号码自动生成标签

<template>
  <div>
    <!-- <label class="labelname">{{labelname}}</label> -->
    <div class="inputbox">
      <div class="arrbox">
        <div v-for="(item, index) in labelarr" :key="index" class="spanbox">
          <span>{{ item }}</span>
          <i class="spanclose" @click="removeitem(index, item)"></i>
        </div>
        <input
          placeholder="输入后回车"
          size="5"
          v-model="currentval"
          @keyup.enter="addlabel"
          @mouseleave="addlabel"
          maxlength="11"
          class="input"
          type="text"
        />
      </div>
    </div>
    <!-- 常用label展示 -->
    <div></div>
  </div>
</template>
<script>
export default {
  name: "enterlabel",
  props: {
    parentarr: {
      type: Array,
      default() {
        return [];
      },
    },
  },
  data() {
    return {
      currentval: "",
      labelarr: [],
    };
  },
  watch: {
    labelarr(old, cur) {
      this.$emit("on-change", this.labelarr);
    },
    parentarr() {
      if (this.parentarr.length > 0) {
        this.labelarr = [];
        for (let i = 0; i < this.parentarr.length; i++) {
          this.labelarr.push(this.parentarr[i]);
        }
      } else {
        this.labelarr = [];
      }
    },
  },
  methods: {
    // 移除标签
    removeitem(index, item) {
      this.labelarr.splice(index, 1);
    },
    // input回车加入labelarr中
    addlabel() {
      let count = this.labelarr.indexOf(this.currentval);
      var re =/^((\+|00)86)?((134\d{4})|((13[0-3|5-9]|14[1|5-9]|15[0-9]|16[2|5|6|7]|17[0-8]|18[0-9]|19[0-2|5-9])\d{8}))$/;
      let str = this.currentval;
      if (count === -1 && re.test(str)) {
        this.labelarr.push(this.currentval);
      }
      else{
        this.$message.error("你输入的电话号码不正确")
      }
      this.currentval = "";
    },
  },
};
</script>
<style>
.inputbox {
  background-color: white;
  font-size: 12px;
  border: 1px solid #dcdee2;
  border-radius: 6px;
  margin-bottom: 18px;
  padding: 6px 1px 1px 6px;
  text-align: left;
  font-size: 0;
  margin-bottom: 0;
}
.input {
  font-size: 14px;
  border: none;
  box-shadow: none;
  outline: none;
  background-color: transparent;
  padding: 0;
  margin: 0;
  width: 200px;
  max-width: inherit;
  min-width: 80px;
  vertical-align: top;
  height: 30px;
  color: #34495e;
  margin: 2px;
  line-height: 30px;
}
.arrbox {
  border-radius: 6px;
  margin-bottom: 10px;
  padding: 6px 1px 1px 6px;
  text-align: left;
  font-size: 0;
}
.spanbox {
  line-height: 30px;
  margin: 2px;
  padding: 0 10px;
  background-color: #1abc9c;
  color: white;
  border-radius: 4px;
  font-size: 13px;
  cursor: pointer;
  display: inline-block;
  position: relative;
  vertical-align: middle;
  overflow: hidden;
  transition: 0.25s linear;
}
.spanbox:hover {
  padding: 0px 17px 0 3px;
}
.spanclose {
  color: white;
  padding: 0 10px 0 0;
  cursor: pointer;
  font-size: 12px;
  position: absolute;
  right: -3px;
  text-align: right;
  text-decoration: none;
  top: 0;
  width: 100%;
  bottom: 0;
  z-index: 2;
  opacity: 0;
  filter: "alpha(opacity=0)";
  transition: opacity 0.25s linear;
  font-style: normal;
}
.spanbox:hover .spanclose {
  padding: 0 10px 5px 0;
  opacity: 1;
  -webkit-filter: none;
  filter: none;
}
.spanclose:after {
  content: "x";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 27px;
}
</style>

效果图

当要一次性添加多个电话号码(粘贴复制)生成标签,可以参考下方代码改动。

addlabel() {
      let count = this.labelarr.indexOf(this.currentval);
      var re = /^((\+|00)86)?((134\d{4})|((13[0-3|5-9]|14[1|5-9]|15[0-9]|16[2|5|6|7]|17[0-8]|18[0-9]|19[0-2|5-9])\d{8}))$/;
      let str = this.currentval.replace(/\s*/g,"");
      // str.prototype.notempty = function(){
      //     return this.filter(t => t!=undefined && t!==null);
      // }
      console.log(str)
      for ( let i = 0; i < (str.length-1) ;){
         if( count === -1 && re.test( str.slice(i,i+11))){
           this.phoneData.push(str.slice(i,i+11))
          for(let j = 0;j < ( this.phoneData.length-1) ;j++){
            const Datas = [...new Set(this.phoneData)];
            this.labelarr = Datas;
          }
        }else{
          this.$message.error("你输入的电话号码不正确");
        }
        i+=11
      }
      console.log(this.labelarr)
      this.currentval = "";
    },
相关文章
|
6月前
表单项validator的校验tip未撑起高度,导致遮盖下边项的内容
表单项validator的校验tip未撑起高度,导致遮盖下边项的内容
32 0
表单项validator的校验tip未撑起高度,导致遮盖下边项的内容
|
5月前
去除程序名称 去除程序属性详细信息中的程序名称 创建时间等信息
去除程序名称 去除程序属性详细信息中的程序名称 创建时间等信息
34 0
|
6月前
|
JavaScript 算法 Java
看不惯各种信息收集表,我手写了一个身份证号输入组件
`shigen`是一位专注于Java、Python、Vue和Shell等技术的博主,分享知识和成长经历。为应对需频繁输入身份证号码的情况,`shigen`决定研究身份证校验机制。研究过程中,了解到身份证号码的生成规则,包括18位数字及校验码计算。通过编写JavaScript代码,实现了两个级别的身份证号码验证:一级仅检查基本格式,二级则加入校验码计算,确保符合生成规则。代码示例展示了逐步增强的验证功能,防止随意修改身份证号码。欢迎交流讨论,共同进步!
66 3
看不惯各种信息收集表,我手写了一个身份证号输入组件
|
存储 C++ Python
C++-筛选文件夹中符合要求的文件并拷贝出来(以手机号码查找为例)
C++-筛选文件夹中符合要求的文件并拷贝出来(以手机号码查找为例)
|
移动开发 前端开发 数据格式
如何处理数据格式字符串让它加上标签
如何处理数据格式字符串让它加上标签
76 0
|
索引
v-for中动态校验el-form表单项代码示例
v-for中动态校验el-form表单项代码示例
236 0
|
Java
输入源“/body/sub_mchid”映射到字段“子商户号”必填性规则校验失败,此字段为必填项
输入源“/body/sub_mchid”映射到字段“子商户号”必填性规则校验失败,此字段为必填项
775 0
Word 技术篇-文档中不同级别标题自动重新编号设置方法,论文多级编号演示
Word 技术篇-文档中不同级别标题自动重新编号设置方法,论文多级编号演示
1412 0
Word 技术篇-文档中不同级别标题自动重新编号设置方法,论文多级编号演示
|
数据安全/隐私保护
注册与登录中相关字段格式的正则表达式验证
注册与登录中相关字段格式的正则表达式验证
111 0
条码标签打印软件如何实现标签重复打印
重复打印是批量打印中的一种重要的打印方式。在批量打印条码、标签、图片的时候经常会遇到,把同一个标签重复打印多份,或者是把同一张标签纸重复打印多张。那么在条码标签打印软件中如何实现重复打印的呢?下面介绍两种重复打印的方式。
2147 0