代码在jsfiddle上有效,但不在我的网站上有效?

时间:2018-10-12 09:03:46

标签: javascript php html credit-card

嘿,所以最近我在网上找到了一些代码,当时正在寻找一种可以识别信用卡类型的方法,我在jsfiddle.net上尝试了该代码,它似乎可以正常工作,直到我决定将代码复制并粘贴到一个空白的.php文件中,该代码将会出现,我没有收到任何错误,但它只是不会做它应该做的事情。我在错误的地方输入代码吗?

这是原始JSfiddle的链接:http://jsfiddle.net/ipsjolly/9whmL9u0/

这是我的.php文件:

<input type="text" class="ckthis">

<div class="showThis"></div>  
   <br><br> 
    SAMPLE TEST NUMBERS
<br><br>

    VISA:
4539435089757850
<br><br>


    <script>
    function detectCardType(number) {
    var re = {
        electron: /^(4026|417500|4405|4508|4844|4913|4917)\d+$/,
        maestro: /^(5018|5020|5038|5612|5893|6304|6759|6761|6762|6763|0604|6390)\d+$/,
        dankort: /^(5019)\d+$/,
        interpayment: /^(636)\d+$/,
        unionpay: /^(62|88)\d+$/,
        visa: /^4[0-9]{12}(?:[0-9]{3})?$/,
        mastercard: /^5[1-5][0-9]{14}$/,
        amex: /^3[47][0-9]{13}$/,
        diners: /^3(?:0[0-5]|[68][0-9])[0-9]{11}$/,
        discover: /^6(?:011|5[0-9]{2})[0-9]{12}$/,
        jcb: /^(?:2131|1800|35\d{3})\d{11}$/
    };
    if (re.electron.test(number)) {
        return 'ELECTRON';
    } else if (re.maestro.test(number)) {
        return 'MAESTRO';
    } else if (re.dankort.test(number)) {
        return 'DANKORT';
    } else if (re.interpayment.test(number)) {
        return 'INTERPAYMENT';
    } else if (re.unionpay.test(number)) {
        return 'UNIONPAY';
    } else if (re.visa.test(number)) {
        return 'VISA';
    } else if (re.mastercard.test(number)) {
        return 'MASTERCARD';
    } else if (re.amex.test(number)) {
        return 'AMEX';
    } else if (re.diners.test(number)) {
        return 'DINERS';
    } else if (re.discover.test(number)) {
        return 'DISCOVER';
    } else if (re.jcb.test(number)) {
        return 'JCB';
    } else {
        return undefined;
    }
}

$(function(){

    $(".ckthis").keyup(function(){
        var thisNum = $(this).val();
        console.log(thisNum);
        $(".showThis").html(detectCardType(thisNum));
    });


});

    </script>

1 个答案:

答案 0 :(得分:1)

我看不到您已经包含了JQuery库。

将其放置在代码中的某个位置(例如,位于底部的<script>标签上方)

<script src="https://code.jquery.com/jquery-3.3.1.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script>

或者,您可以download将整个库本地保存到计算机上,然后以这种方式进行引用。