码迷,mamicode.com
首页 > 其他好文 > 详细

截取指定长度文章点击可以展开全部代码

时间:2015-12-04 10:46:51      阅读:141      评论:0      收藏:0      [点我收藏+]

标签:

截取指定长度文章点击可以展开全部代码:
文章的篇幅往往不是那么恰到好处,如果以原有的篇幅展示,那么有可能会影响网页的布局或者美观度,这个时候就要根据情况适量截取一定的字符串,以适应布局,不过当点击一个按钮的时候依然可以展开全部的内容,下面就通过一个实例详细介绍一下如何实现此效果,代码示例如下:

 

<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>字符串截取展开效果-蚂蚁部落</title>
<style type="text/css">
#thediv{
  width:200px;
  margin:0px auto;
}
</style>
<script type="text/javascript"> 
function cutStr(){ 
  var odiv=document.getElementById("thediv"); 
  var str=odiv.innerHTML; 
  var ospan=document.createElement("span"); 
  var olink=document.createElement("a"); 
  ospan.innerHTML=str.substring(0,20); 
  olink.innerHTML=str.length>20?"...":""; 
  olink.href="###"; 
  olink.onclick=function(){ 
    if(olink.innerHTML=="..."){ 
      olink.innerHTML="收起"; 
      ospan.innerHTML=str; 
    }
    else{ 
      olink.innerHTML="..."; 
      ospan.innerHTML=str.substring(0,20); 
    } 
  } 
  odiv.innerHTML=""; 
  odiv.appendChild(ospan); 
  odiv.appendChild(olink); 
}; 
window.onload=function(){
  cutStr();
}
</script> 
<body>
<div id="thediv">蚂蚁部落欢迎您,个人的力量再强也只是一只强壮的蚂蚁而已,如果有分享和胸怀和合作的精神,那么就有可能活得巨大进步。</div> 
</body>
</html>

 

以上代码实现了我们的要求,截取指定的字符串,后面以"..."结尾,当点击这个结尾的时候,能够展开所有的文字内容,下面就介绍一下此效果的实现过程。
一.实现原理:
创建一个span元素和a元素,然后使用substring()函数截取指定的字符串并将其设置为span元素的内容,然后判断原来字符串的长度是否大于指定长度,如果大于,则将a元素中的内容设置为"..."。然后将原有div清空,然后span元素和a元素添加到div中去,这样就实现了截取功能。为a元素注册时间处理函数,点击此按钮就会执行事件处理函数,此函数首先判断是出于何种状态,如果处于收起状态,那么就会将a元素中的内容设置为"收起",并且将原有所有字符放入span,这样就实现了展开,如果出于展开状态,那么就是截取字符和修改a元素中的内容。原理大体如此,可以参阅相关阅读。
二.相关阅读:
1.createElement()函数可以参阅js的createElement()和appendChild()函数的作用一章节。
2.substring()函数可以参阅javascript的String对象的substring()方法一章节。
3.olink.href="###"可以参阅javascript:void(0)用法简单介绍一章节。 
4.onclick事件可以参阅javascript的onclick事件一章节。

原文地址是:http://www.softwhy.com/forum.php?mod=viewthread&tid=9206

更多内容可以参阅http://www.softwhy.com/jsshili/

 

截取指定长度文章点击可以展开全部代码

标签:

原文地址:http://www.cnblogs.com/xiaofinder/p/5018436.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!