不同的方式的实现Table不换行省略号显示
来源:互联网 发布:查日本经济数据的网站 编辑:程序博客网 时间:2024/05/16 17:20
又是一个阳光明媚的早晨,最近有点闲就也谢谢文章,
今天先上效果图
接下来就是令人期待的源码啦,上
line_change.html<!DOCTYPE html><html><script type="text/javascript" src="jquery-3.1.1.min.js"></script><script type="text/javascript" src="line_change2.js"></script><style>table {border-collapse: collapse;border-spacing: 0;}th,td {padding: 0;}</style><head><meta charset="UTF-8"><title></title></head><body><table style="width: 100%;"><tr class="line_zyq"><td></td><td></td><td></td><td></td><td></td></tr><tr class="line_zyq"><td></td><td></td><td></td><td></td><td></td></tr><tr class="line_zyq"><td></td><td></td><td></td><td></td><td></td></tr><tr class="line_zyq"><td></td><td></td><td></td><td></td><td></td></tr></table></body></html>line_change2.js//如果添加了padding属性请自行修改var tr_tds = [["我忘了闹分手的放他", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手我的", "我忘了闹分手我忘了闹分手我忘了闹分手", "我忘了闹分手的", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手"],["我忘了闹分手的放他", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手我的", "我忘了闹分手我忘了闹分手我忘了闹分手", "我忘了闹分手的", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手"],["我忘了闹分手的放他", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手我的", "我忘了闹分手我忘了闹分手我忘了闹分手", "我忘了闹分手的", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手"],["我忘了闹分手的放他", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手我的", "我忘了闹分手我忘了闹分手我忘了闹分手", "我忘了闹分手的", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手"]]var tr_tds_html = [["我忘了闹分手的放他", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手我的", "我忘了闹分手我忘了闹分手我忘了闹分手", "我忘了闹分手的", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手"],["我忘了闹分手的放他", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手我的", "我忘了闹分手我忘了闹分手我忘了闹分手", "我忘了闹分手的", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手"],["我忘了闹分手的放他", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手我的", "我忘了闹分手我忘了闹分手我忘了闹分手", "我忘了闹分手的", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手"],["我忘了闹分手的放他", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手我的", "我忘了闹分手我忘了闹分手我忘了闹分手", "我忘了闹分手的", "我忘了闹分手我忘了闹分手我忘了闹分手我忘了闹分手"]]var windowWidth=0;function line_change() {$(".line_zyq").each(function(n) {var s = $(this).css("font-size");var ss = s.substring(0, s.length - 2);//当前行可以放的最大字数var lineNum=$(this).width() / parseInt(ss)var sum = 0;for(var i=0;i<tr_tds[n].length;i++){sum += tr_tds[n][i].length;}if(lineNum>sum){$(this).children().each(function(m) {$(this).text(tr_tds[n][m])});}else{//放不下需处理//算出平均的列宽var defaultColWidth=$(this).width()/tr_tds[n].length;//算出平均每列可以放几个字var defaultColFontNum=lineNum/tr_tds[n].length;//存放每列有几个字var tds=[];//算出真实情况的每列应该放几个字var colFontNum=[];for(var i=0;i<tr_tds[n].length;i++){tds[i]=tr_tds[n][i].length;}tds=tds.sort(function(a,b){return a-b;});//alert(tds+" "+defaultColFontNum);var newLineNum=lineNum;for(var i=0;i<tds.length;i++){//这个判断条件可以按照大家的想法修改if(tds[i]<defaultColFontNum){colFontNum[i]=tds[i];newLineNum-=tds[i];defaultColFontNum=(newLineNum)/(tr_tds[n].length-1-i);}else{colFontNum[i]=defaultColFontNum;}}//alert(tds+" "+colFontNum);$(this).children().each(function(m){for(var i=0;i<tds.length;i++){if(tds[i]==tr_tds[n][m].length){$(this).html("<span title='"+tr_tds_html[n][m]+"'>"+tr_tds[n][m].substring(0,colFontNum[i]-1)+"...</span>");}}});}//alert(sum + " " + $(this).width() / parseInt(ss));});}$(document).ready(line_change);$(window).resize(function (){if(windowWidth != $(window).width()) {windowWidth = $(window).width();line_change();}})
好啦又到了结束的时间,希望对大家有帮助。
阅读全文
0 0
- 不同的方式的实现Table不换行省略号显示
- 使table中td的内容不换行显示,多余时出现省略号
- flex布局文本不换行不显示省略号的解决方法
- CSS 强制不换行,多出的文字显示省略号
- 文本不换行,显示省略号
- css 不换行显示省略号
- html div 不换行超出显示省略号
- 文本不换行,超出显示省略号
- html div 不换行超出显示省略号
- 文字不换行,超出部分显示省略号
- android textview省略号显示的方式
- Bootstrap table 莫名其妙的不换行问题
- CSS 实现表格中文字不换行,超长部分显示省略号
- linux下printf实现不换行打印(printf显示不加换行的缓冲问题)
- css控制不溢出,不换行,溢出部分省略号显示
- css控制不溢出,不换行,溢出部分省略号显示
- CSS Table不换行与换行的用法
- Android 实现复制到系统剪贴板 TextView 实现单行输入,禁止换行,多出来的显示省略号
- Drawer与Toolbar的简单使用
- 连咸鱼都能学会的Java动态代理
- JS 获取当月第一天与最后一天
- URG-PSH
- 解决svn图标不显示的各种问题
- 不同的方式的实现Table不换行省略号显示
- Session hijacking(会话劫持)
- vb.net版机房重构--存储过程的使用
- 数字电路中的时序分析(一)
- TP3.2校验微信公众号、小程序 服务器地址
- 剑指Offer_面试题15_链表中倒数第k个结点
- mysql中bigint、int、mediumint、smallint 和 tinyint的取值范围
- R语言-循环方式
- flowable任务监听器获取spring bean