Discuz教程网

基于Jquery的文字自动截取(提供源代码)

[复制链接]
authicon dly 发表于 2011-9-12 15:13:38 | 显示全部楼层 |阅读模式
插件需求(功能需要)
一个插件就是完成一个特定的功能,我们在动手制作一个插件时应该确定该插件开发完成后应具备哪些功能供我们使用。
在某天早上,按模式的完成开机、连接数据库、开启VS开发环境、调试程序。程序跑起了,可是页面中的有段内容超过了页面所容许的范围。这还不容易哟,SubString呗,
对,这的确是个好法子,能解决这类问题,但当页面需要被处理过后的内容进行交互,这种方法难免有点不适应了,那么我们就使用Jquery开发一个满足该需求的插件吧;
开发须知
如果您对使用Jquery开发插件的流程不是很连接,请查考本篇文章:开发Jquery插件(一)(包含最终效果图)
一步一步开发Jquery插件----文字自动缩放
首先我们应该想到为了以后扩展该插件,条件不应该写死在程序中,那么该插件应该具备这么几个参数:Length(限制长度)、Replace(被替换后的文字)、ShowMore(显示全部的按钮)、HideMore(隐藏过多的文字);
1、在Jquery开发插件时,它提供向插件传递参数和使用默认定义好的参数,一般写法应用如下:
  1. $.fn.MyFunction= function(options) {//options为我们传递的参数数组;
  2. var defaults = {
  3. arg1: ...,
  4. arg2: "...",
  5. argN: "",
  6. replace: "..."
  7. };
  8. var options = $.extend(defaults, options);
复制代码

那么针对我们今天开发的这个插件,对应的插件参数如下:
  1. $.fn.HideMore= function(options) {
  2. var defaults = {
  3. length: 10,
  4. showmore: "更多",
  5. hidemore: "隐藏",
  6. replace: "..."
  7. };
  8. var options = $.extend(defaults, options);
复制代码

2、那接下来的工作大致流程如下:
i、获取Div中的内容长度;
ii、与传递至插件的length的值比较;
iii、如果长度超过length就截取并替换;
iiii、对showmore和hidemore定义事件;
插件源代码:
  1. (function($) {
  2. $.fn.HideMore = function(options) {
  3. var defaults = {
  4. length: 10,
  5. showmore: "更多",
  6. hidemore: "隐藏",
  7. replace: "..."
  8. };
  9. var options = $.extend(defaults, options);
  10. var objhtml = $(this).html();
  11. if (objhtml.length > options.length) {
  12. var precontent = objhtml.substring(0, options.length);
  13. var lastcontent = "" + objhtml.substring(options.length, objhtml.length) + "";
  14. var morelink = "" + options.showmore + "";
  15. var newcontent = precontent + lastcontent +
  16. options.replace + morelink;
  17. $(this).html(newcontent);
  18. $(".more").css("display", "none");
  19. $(".morelink").click(function() {
  20. if ($(".morelink").html() == options.showmore) {
  21. $(".more").show(1000);
  22. $(".morelink").html(options.hidemore);
  23. return false;
  24. }
  25. else {
  26. $(".more").hide(900);
  27. $(".morelink").html(options.showmore);
  28. return false;
  29. }
  30. });
  31. }
  32. return false;
  33. };
  34. })(jQuery);
复制代码

Html测试代码:
  1. $("elements").HideMore(
  2. {
  3. length:50,
  4. showmore"展",
  5. hidemore"缩",
  6. replace:"......"
  7. });
复制代码

好了,读者看到这里不妨把代码COPY并运行吧。您的第二个插件就诞生咯。



上一篇:Javascript实现的类似Google的Div拖动效果代码
下一篇:JQuery动态创建DOM、表单元素的实现代码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1314学习网 ( 浙ICP备10214163号 )

GMT+8, 2025-5-2 20:10

Powered by Discuz! X3.4

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表