vue iview 输入银行卡号匹配开户行

vue 文件中引用

<template>
    <!--建议用@on-change=""[可实时监听输入的每一个数字及所在银行匹配];@on-blur=""只能是移除框才触发-->
    <Input placeholder="银行卡号" v-model="preStoreUtils.cardNumber" @on-change="refoundNumber"></Input>
    <!--根据上面输入的银行卡号自动匹配所在银行,两者联用,可得到效果-->
    <Input placeholder="开户银行" v-model="preStoreUtils.openingBank" readonly></Input>
</template>

<script>
    //此步骤是为了 引入银行卡号类型匹配的工具类 目录以自己的文件目录为主
    import {
   bankCardAttribution} from '../../../../../libs/bankNoPatterns.js';
    export default {
   
        name: 'test',
        data () {
   
            return {
   
                preStoreUtils: {
   }
            };
        },
        watch: {
   
            //此步骤是为了更清楚的格式化银行卡号,每4位一个空格
            'preStoreUtils.cardNumber'(val) {
   
                this.$nextTick(() => {
   
                    this.preStoreUtils.cardNumber = val
                        .replace(/\D/g, '')
                        .replace(/....(?!$)/g, '$& ');
                });
            }
        },
        methods: {
   
            // 此步骤是银行卡号匹配银行类型的方法
            refoundNumber() {
   
                let number = this.preStoreUtils.cardNumber;
                let num = number.replace(/\s+/g, '');
                let obj = bankCardAttribution(num);
                if (obj === 'error') {
   
                    this.$Message.error('请输入正确的银行卡号!');
                } else {
   
                    this.preStoreUtils.openingBank = obj.bankName;
                }
            },
        }

    };
</script>

<style scoped>

</style>

银行卡类型判断工具类

//
// 版权所有:xxxxxx技术有限公司,2018
// 内容描述:<银行卡类型判断>
//  作者:王姣姣
//  创建时间:2019-07-15
//  版本          开发者            日期              描述
//  1.0.0.0      王姣姣           2019-07-15          新建
//
export function bankCardAttribution (bankCard) {
   
    var cardTypeMap = {
   
        DC: '储蓄卡',
        CC: '信用卡',
        SCC: '准贷记卡',
        PC: '预付费卡'
    };

    function extend (target, source) {
   
        var result = {
   };
        var key;
        target = target || {
   };
        source = source || {
   };
        for (key in target) {
   
            if (target.hasOwnProperty(key)) {
   
                result[key] = target[key];
            }
        }
        for (key in source) {
   
            if (source.hasOwnProperty(key)) {
   
                result[key] = source[key];
            }
        }
        return result;
    }

    function getCardTypeName (cardType) {
   
        if (cardTypeMap[cardType]) {
   
            return cardTypeMap[cardType];
        }
        return undefined;
    }

    var bankcardList = [{
   
        bankName: '中国邮政储蓄银行',
        bankCode: 'PSBC',
        patterns: [{
   
            reg: /^(621096|621098|622150|622151|622181|622188|622199|955100|621095|620062|621285|621798|621799|621797|620529|621622|621599|621674|623218|623219)\d{13}$/g,
            cardType: 'DC'
        }, {
   
            reg: /^(62215049|62215050|62215051|62218850|62218851|62218849)\d{11}$/g,
            cardType: 'DC'
        }, {
   
            reg: /^(622812|622810|622811|628310|625919)\d{10}$/g,
            cardType: 'CC'
        }]
    }, {
   
        bankName: '中国工商银行',
        bankCode: 'ICBC',
        patterns: [{
   
            reg: /^(620200|620302|620402|620403|620404|620406|620407|620409|620410|620411|620412|620502|620503|620405|620408|620512|620602|620604|620607|620611|620612|620704|620706|620707|620708|620709|620710|620609|620712|620713|620714|620802|620711|620904|620905|621001|620902|621103|621105|621106|621107|621102|621203|621204|621205|621206|621207|621208|621209|621210|621302|621303|621202|621305|621306|621307|621309|621311|621313|621211|621315|621304|621402|621404|621405|621406|621407|621408|621409|621410|621502|621317|621511|621602|621603|621604|621605|621608|621609|621610|621611|621612|621613|621614|621615|621616|621617|621607|621606|621804|621807|621813|621814|621817|621901|621904|621905|621906|621907|621908|621909|621910|621911|621912|621913|621915|622002|621903|622004|622005|622006|622007|622008|622010|622011|622012|621914|622015|622016|622003|622018|622019|622020|622102|622103|622104|622105|622013|622111|622114|622017|622110|622303|622304|622305|622306|622307|622308|622309|622314|622315|622317|622302|622402|622403|622404|622313|622504|622505|622509|622513|622517|622502|622604|622605|622606|622510|622703|622715|622806|622902|622903|622706|623002|623006|623008|623011|623012|622904|623015|623100|623202|623301|623400|623500|623602|623803|623901|623014|624100|624200|624301|624402|623700|624000)\d{12}$/g,
            cardType: 'DC'
        }, {
   
            reg: /^(622200|622202|622203|622208|621225|620058|621281|900000|621558|621559|621722|621723|620086|621226|621618|620516|621227|621288|621721|900010|623062|621670|621720|621379|621240|621724|621762|621414|621375|622926|622927|622928|622929|622930|622931|621733|621732|621372|621369|621763)\d{13}$/g,
            cardType: 'DC'
        }, {
   
            reg: /^(402791|427028|427038|548259|621376|621423|621428|621434|621761|621749|621300|621378|622944|622949|621371|621730|621734|621433|621370|621764|621464|621765|621750|621377|621367|621374|621731|621781)\d{10}$/g,
            cardType: 'DC'
        },
        {
   
            reg: /^(9558)\d{15}$/g,
            cardType: 'DC'
        },
        {
   
            reg: /^(370246|370248|370249|370247|370267|374738|374739)\d{9}$/g,
            cardType: 'CC'
        }, {
   
            reg: /^(427010|427018|427019|427020|427029|427030|427039|438125|438126|451804|451810|451811|458071|489734|489735|489736|510529|427062|524091|427064|530970|530990|558360|524047|525498|622230|622231|622232|622233|622234|622235|622237|622239|622240|622245|622238|451804|451810|451811|458071|628288|628286|622206|526836|513685|543098|458441|622246|544210|548943|356879|356880|356881|356882|528856|625330|625331|625332|622236|524374|550213|625929|625927|625939|625987|625930|625114|622159|625021|625022|625932|622889|625900|625915|625916|622171|625931|625113|625928|625914|625986|625925|625921|625926|625942|622158|625917|625922|625934|625933|625920|625924|625017|625018|625019)\d{10}$/g,
            cardType: 'CC'
        },
        {
   
            reg: /^(45806|53098|45806|53098)\d{11}$/g,
            cardType: 'CC'
        }, {
   
            reg: /^(622210|622211|622212|622213|622214|622220|622223|622225|622229|622215|622224)\d{10}$/g,
            cardType: 'SCC'
        }, {
   
            reg: /^(620054|620142|620184|620030|620050|620143|620149|620124|620183|620094|620186|620148|620185)\d{10}$/g,
            cardType: 'PC'
        }, {
   
            reg: /^(620114|620187|620046)\d{13}$/g,
            cardType: 'PC'
        }]
    }, {
   
        bankName: '中国农业银行',
        bankCode: 'ABC',
        patterns: [{
   
            reg: /^(622841|622824|622826|622848|620059|621282|622828|622823|621336|621619|622821|622822|622825|622827|622845|622849|623018|623206|621671|622840|622843|622844|622846|622847|620501)\d{13}$/g,
            cardType: 'DC'
        },
        {
   
            reg: /^(95595|95596|95597|95598|95599)\d{14}$/g,
            cardType: 'DC'
        },
        {
   
            reg: /^(103)\d{16}$/g,
            cardType: 'DC'
        }, {
   
            reg: /^(403361|404117|404118|404119|404120|404121|463758|519412|519413|520082|520083|552599|558730|514027|622836|622837|628268|625996|625998|625997|622838|625336|625826|625827|544243|548478|628269)\d{10}$/g,
            cardType: 'CC'
        }, {
   
            reg: /^(622820|622830)\d{10}$/g,
            cardType: 'SCC'
        }]
    }, {
   
        bankName: '中国银行',
        bankCode: 'BOC',
        patterns: [{
   
            reg: /^(621660|621661|621662|621663|621665|621667|621668|621669|621666|456351|601382|621256|621212|621283|620061|621725|621330|621331|621332|621333|621297|621568|621569|621672|623208|621620|621756|621757|621758|621759|621785|621786|621787|621788|621789|621790|622273|622274|622771|622772|622770|621741|621041)\d{13}$/g,
            cardType: 'DC'
        }, {
   
            reg: /^(621293|621294|621342|621343|621364|621394|621648|621248|621215|621249|621231|621638|621334|621395|623040|622348)\d{10}$/g,
            cardType: 'DC'
        }, {
   
            reg: /^(625908|625910|625909|356833|356835|409665|409666|409668|409669|409670|409671|409672|512315|512316|512411|512412|514957|409667|438088|552742|553131|514958|622760|628388|518377|622788|628313|628312|622750|622751|625145|622479|622480|622789|625140|622346|622347)\d{10}$/g,
            cardType: 'CC'
        }, {
   
            reg: /^(518378|518379|518474|518475|518476|524865|525745|525746|547766|558868|622752|622753|622755|524864|622757|622758|622759|622761|622762|622763|622756|622754|622764|622765|558869|625905|625906|625907|625333)\d{10}$/g,
            cardType: 'SCC'
        },
        {
   
            reg: /^(53591|49102|377677)\d{11}$/g,
            cardType: 'SCC'
        }, {
   
            reg: /^(620514|620025|620026|620210|620211|620019|620035|620202|620203|620048|620515|920000)\d{10}$/g,
            cardType: 'PC'
        }, {
   
            reg: /^(620040|620531|620513|921000|620038)\d{13}$/g,
            cardType: 'PC'
        }]
    }, {
   
        bankName: '中国建设银行',
        bankCode: 'CCB',
        patterns: [{
   
            reg: /^(621284|436742|589970|620060|621081|621467|621598|621621|621700|622280|622700|623211|623668)\d{13}$/g,
            cardType: 'DC'
        }, {
   
            reg: /^(421349|434061|434062|524094|526410|552245|621080|621082|621466|621488|621499|622966|622988|622382|621487|621083|621084|620107)\d{10}$/g,
            cardType: 'DC'
        },
        {
   
            reg: /^(436742193|622280193)\d{10}$/g,
            cardType: 'DC'
        },
        {
   
            reg: /^(553242)\d{12}$/g,
            cardType: 'CC'
        }, {
   
            reg: /^(625362|625363|628316|628317|356896|356899|356895|436718|436738|436745|436748|489592|531693|532450|532458|544887|552801|557080|558895|559051|622166|622168|622708|625964|625965|625966|628266|628366|622381|622675|622676|622677)\d{10}$/g,
            cardType: 'CC'
        }, {
   
            reg: /^(5453242|5491031|5544033)\d{11}$/g,
            cardType: 'CC'
        }, {
   
            reg: /^(622725|622728|436728|453242|491031|544033|622707|625955|625956)\d{10}$/g,
            cardType: 'SCC'
        }, {
   
            reg: /^(53242|53243)\d{11}$/g,
            cardType: 'SCC'
        }]
    }, {
   
        bankName: '中国交通银行',
        bankCode: 'COMM',
        patterns: [
            {
   
                reg: /^(622261|622260|622262|621002|621069|621436|621335)\d{13}$/g,
                cardType: 'DC'
            },
            {
   
                reg: /^(620013)\d{10}$/g,
                cardType: 'DC'
            },
            {
   
                reg: /^(405512|601428|405512|601428|622258|622259|405512|601428)\d{11}$/g,
                cardType: 'DC'
            },
            {
   
                reg: /^(49104|53783)\d{11}$/g,
                cardType: 'CC'
            }, {
   
                reg: /^(434910|458123|458124|520169|522964|552853|622250|622251|521899|622253|622656|628216|622252|955590|955591|955592|955593|628218|625028|625029)\d{10}$/g,
                cardType: 'CC'
            }, {
   
                reg: /^(622254|622255|622256|622257|622284)\d{10}$/g,
                cardType: 'SCC'
            }, {
   
                reg: /^(620021|620521)\d{13}$/g,
                cardType: 'PC'
            }]
    }, {
   
        bankName: '招商银行',
        bankCode: 'CMB',
        patterns: [{
   
            reg: /^(402658|410062|468203|512425|524011|622580|622588|622598|622609|95555|621286|621483|621485|621486|621299)\d{10}$/g,
            cardType: 'DC'
        },
        {
   
            reg: /^(690755)\d{9}$/g,
            cardType: 'DC'
        },
        {
   
            reg: /^(690755)\d{12}$/g,
            cardType: 'DC'
        }, {
   
            reg: /^(356885|356886|356887|356888|356890|439188|439227|479228|479229|521302|356889|545620|545621|545947|545948|552534|552587|622575|622576|622577|622578|622579|545619|622581|622582|545623|628290|439225|518710|518718|628362|439226|628262|625802|625803)\d{10}$/g,
            cardType: 'CC'
        }, {
   
            reg: /^(370285|370286|370287|370289)\d{9}$/g,
            cardType: 'CC'
        }, {
   
            reg: /^(620520)\d{13}$/g,
            cardType: 'PC'
        }]
    }, {
   
        bankName: '中国民生银行',
        bankCode: 'CMBC',
        patterns: [{
   
            reg: /^(622615|622616|622618|622622|622617|622619|415599|421393|421865|427570|427571|472067|472068|622620)\d{10}$/g,
            cardType: 'DC'
        }, {
   
            reg: /^(545392|545393|545431|545447|356859|356857|407405|421869|421870|421871|512466|356856|528948|552288|622600|622601|622602|517636|622621|628258|556610|622603|464580|464581|523952|545217|553161|356858|622623|625912|625913|625911)\d{10}$/g,
            cardType: 'CC'
        }, {
   
            reg: /^(377155|377152|377153|377158)\d{9}$/g,
            cardType: 'CC'
        }]
    }, {
   
        bankName: '中国光大银行',
        bankCode: 'CEB',
        patterns
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值