最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - When using JQuery Linkify plugin, how do I truncate the url? - Stack Overflow

programmeradmin1浏览0评论

I'm using this plugin. It works, and everything's fine. But is there an option I can plug into it so that if the url length is longer than "X", then truncate it, and add "..."?

Right now the URLs are so long.

I notice in the demo there is a "handleLinks" callback function, but how do I use that?

https://github./maranomynet/linkify

I'm using this plugin. It works, and everything's fine. But is there an option I can plug into it so that if the url length is longer than "X", then truncate it, and add "..."?

Right now the URLs are so long.

I notice in the demo there is a "handleLinks" callback function, but how do I use that?

Share Improve this question asked Feb 6, 2012 at 6:38 TIMEXTIMEX 273k367 gold badges802 silver badges1.1k bronze badges 1
  • If you will cut the link then it will be useless as a link but if you want to display it like this then you can implement some other jQuery plugin to implement this. – Naveed Commented Feb 6, 2012 at 6:56
Add a ment  | 

2 Answers 2

Reset to default 9 +300

You're right, you can use handleLinks callback function. For example I wrote simple functional that you need:

handleLinks: function (links) {
    for (var i = 0, cnt = links.length, tmpLink; i < cnt; i++) {
        tmpLink = links[i].innerHTML;
        if (tmpLink.length > 10) {
            links[i].innerHTML = tmpLink.substr(0, 10) + '...';
        }
    }
}

It truncates links if they longer than 10 characters. You can modify this script by your needs.

For URL truncating I choose to shorten in the middle, as the domain and file are usually more important than the directory path.

Taken and adapted for this question from my GitHub fork of Andrew Plummer's JavaScript Library Sugar.

String.prototype.shorten = function(length, position, countSplitter, splitter) {
  if (this.length < 1 && length < 1) return String(this);

  if (!(typeof(splitter) === 'string')) splitter = '...';
  if (!(typeof(countSplitter) === 'boolean')) countSplitter = true;

  var balance = (countSplitter) ? splitter.length : 0;

  if (length <= balance || this.length <= length) return String(this);

  // Perform shortening
  var shortened, beforeSplitter, afterSplitter;

  if (position == 'left') {
    afterSplitter = this.substring(this.length - length + balance, this.length - 1);
    shortened = splitter + afterSplitter;
  } else if (position == 'right') {
    beforeSplitter = this.substring(0, length - balance);
    shortened = beforeSplitter + splitter;
  } else {
    beforeSplitter = this.substring(0, Math.ceil((length / 2) - (balance / 2)));
    afterSplitter = this.substring(this.length - Math.floor((length / 2) - (balance / 2)), this.length);
    shortened = beforeSplitter + splitter + afterSplitter;
  }

  return shortened;
}

Example of shortening a Url so the resultant string is 20 characters long:

var toShorten = 'http://stackoverflow./questions/9156458/when-using-jquery-linkify-plugin-how-do-i-truncate-the-url';
var shortened = toShorten.shorten(20); // Output: 'http://st...-the-url'

Note: this code has only been proof read and not unit tested. The Sugar implementation has been unit tested, however.

发布评论

评论列表(0)

  1. 暂无评论