Jquery Twitter Like 字符计数器偏移缩短链接

标签 jquery regex url-shortener charactercount

你好,我正在尝试模仿 Twitter 上的字符计数器。因此,当您键入或粘贴时,限制会减少。但我正在编写的服务也会有一个 url 缩短器,所以我想用最终 URL 的字符数来抵消它。缩短发生在发布端,而不是在您输入 URL 时发生。

我几乎一切都在工作,但是当我单击元素时,偏移量不再存在,并且字符数设置回链接全长时的数量。我相信这是因为我使用 .change() 方法而不是 .bind("input Paste") 但输入粘贴没有应用偏移量。

/* Character Count for Posts */                
function checkPostForURL(post){
    var matches = [],
        urlexp = new RegExp("(^|[ \t\r\n])((http|https):(([A-Za-z0-9$_.+!*(),;/?:@&~=-])|%[A-Fa-f0-9]{2}){2,}(#([a-zA-Z0-9][a-zA-Z0-9$_.+!*(),;/?:@&~=%-]*))?([A-Za-z0-9$_+!*();/?:~-]))","g"),
        $linkShort = $('#linkstoshort'),
        matchIdx = 0;

    if ( post !== undefined ){
        if ( urlexp.test(post) ){
               var offset = 0;
               $('.shortenlinks').show();
               matches = post.match(urlexp);

               $linkShort.html('');

                for(; matchIdx < matches.length; matchIdx++) {
                    var match = matches[matchIdx],
                        matchOffset = match.length - 23;

                    offset += matchOffset;

                    $linkShort.append('<li>'+match+'</li>');
                }

                return offset;
        }
    }
 }

$(function(){
    var $postMsg = $('#post-msg'),
        message = $postMsg.text(),
        twstartchars = 140 - message.length,
        fbstartchars = 420 - message.length,
        $fbCount = $("#fb-char"),
        $twCount = $("#tw-char"),
        setRemainingChars = function (evt) {
            var a = $postMsg.val().length,
                post = $postMsg.val();        

            var offset = checkPostForURL(post);
            if ( offset ){
                a = a - offset;
            }

            $fbCount.text((420-a));
            $twCount.text((140-a));
            if ( a > 120 ){
                    $fbCount.css('color','red');
                    if ( a > 380 ){
                            $fbCount.css('color','red');
                    }
            }else{
                    $fbCount.css('color','#333');
                    $twCount.css('color','#333');
            }
        };

    $fbCount.text(fbstartchars);
    $twCount.text(twstartchars);

    $postMsg.on('keypress change', setRemainingChars);
});

更新:我做了一个 JS fiddle 来更好地演示我正在尝试做的事情 http://jsfiddle.net/FUADn/384/

最佳答案

您是否尝试过在输入上绑定(bind) .keyup() 事件而不是更改事件?这在技术上应该可行,并在使用鼠标等后保持绑定(bind)。

关于Jquery Twitter Like 字符计数器偏移缩短链接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8313588/

相关文章:

jquery - 从 jQuery 到 Sharepoint 的页面方法调用

triggers - 触发多事件

regex - 提取字符串中两个符号之间的所有内容

REGEX 在两个值之间查找字符串

open-source - 开源URL缩短软件?

url-shortener - 高流量网站的 URL 缩短器

javascript - 如何松散耦合页面上的 javascript 和模态/jQuery UI 对话框中的 javascript?

javascript - jquery slider 对 ajax 生成的 div 的影响

javascript 使用 RegExp 来查找被遗弃者

firebase - 如果 url 包含 '#',如何使用 google firebase 动态链接缩短 url