使用JS或Jquery检测textarea中的url

时间:2012-08-23 13:57:39

标签: javascript jquery regex textarea

如果用户已经完成输入网址,请如何检测(在textarea或其他输入中),因为Facebook会以其主要形式输入网址吗?

this这样的解决方案可以正常工作,但只有当用户完成输入并执行操作时才会起作用,例如点击按钮。

我希望在整个条目中检测网址,例如检查每个空格后输入的单词。

提前谢谢。

3 个答案:

答案 0 :(得分:7)

以下是有关如何执行此操作的示例:

$(function() {
    "use strict";
    var url = /[-a-zA-Z0-9@:%_\+.~#?&//=]{2,256}\.[a-z]{2,4}\b(\/[-a-zA-Z0-9@:%_\+.~#?&//=]*)?/gi;

    $("#textarea").on("keyup", function( e ) {
        var urls, output = "";
        if ( e.keyCode !== 8 && e.keyCode !== 9 && e.keyCode !== 13 && e.keyCode !== 32 && e.keyCode !== 46 ) {
            // Return is backspace, tab, enter, space or delete was not pressed.
            return;
        }

        while ((urls = url.exec(this.value)) !== null) {
            output += urls[0] + ", ";
        }
        console.log("URLS: " + output.substring(0, output.length - 2));
    });
});

当然,您必须绑定其他事件,例如.blur()才能使其正常工作。

尝试以下小提琴,并在键入时检查控制台:http://jsfiddle.net/sQVe/mXQrc/1/

答案 1 :(得分:6)

看看这个:https://github.com/stephan-fischer/jQuery-LiveUrl/ - 它干净,简单,并提供网址预览!

enter image description here

答案 2 :(得分:0)

您正在寻找的是按键事件,您可以在此处查看文档以及如何使用它的示例:http://api.jquery.com/keypress/