博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
标签样式[请使用空格或逗号分隔不同标签]
阅读量:6281 次
发布时间:2019-06-22

本文共 3005 字,大约阅读时间需要 10 分钟。

在博客中经常看到标签的特效,很实用。如:

标签间请用“空格”或“逗号”隔开

 

请使用空格或回车分隔不同标签
 
 

 
 
  1. <!DOCTYPE HTML> 
  2. <html> 
  3. <head> 
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
  5. <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js" type="text/javascript"></script> 
  6. <style> 
  7. <!-- 
  8. .tips_content { border:1px solid #bbb;width:200px; background:#fff; overflow-x:hidden; _height:30px; min-height:30px;} 
  9. .tips_content ul{list-style-type:none;margin:0px;padding:0px;} 
  10. .tips_content li { line-height: 22px; color: #667C6E; background: #F4F4F4; padding: 0px 3px; float: left; height: 22px; border: 1px solid #D7D7D7; margin:0 5px 5px 0; border-radius:3px; cursor:default; display:inline; white-space: nowrap;font-size:12px;} 
  11. .tips_content li a { font-size:12px;cursor:pointer;text-decoration:none;} 
  12. .tips_content li a:hover {color:#B3BBC3;text-decoration:none;} 
  13. --> 
  14. </style> 
  15. <script> 
  16. // JavaScript Document 
  17. $(function(){ 
  18.     var thisval = $(".tips_content input").val(); 
  19.     var thisul = ".tips_content ul"
  20.     $(".tips_content").click(function(){ 
  21.         //点击标签框的任意位置都使input获得焦点 
  22.         $(this).children("input").focus(); 
  23.     }); 
  24.     //标签后面的“X”绑定单击事件 
  25.     $(".tips_content li a").live("click",function(){ 
  26.         //点击标签的“X”删除此标签 
  27.         $(this).parent().remove();     
  28.         return false; 
  29.     }); 
  30.     //输入框获得焦点时 
  31.     $(".tips_content input").focus(function(){ 
  32.         var fristval = $(this).val(); 
  33.         if(fristval == thisval){ 
  34.             $(this).val("").css("color","#333"); 
  35.             } 
  36.          //按键弹起时,调用jquery的event方法 
  37.         $(this).keydown(function(event){ 
  38.             //定义键盘值,定义输入框的内容 
  39.             var keycode = event.which; 
  40.                     m = $(this).val(); 
  41.             //如果按键是回车或者逗 
  42.             if(keycode == 13||keycode == 188||keycode == 32){ 
  43.                 //取消按键的默认行为 
  44.           event.preventDefault(); 
  45.           event.returnValue = false
  46.                 //去除标签前后的空格 
  47.                 var mm =$.trim(m); 
  48.                 if(mm != ""){ 
  49.                     //添加li到ul 
  50.                     $("<li>"+mm+"<a>×</a></li>").appendTo(thisul); 
  51.                     //清空输入框 
  52.                     $(this).val("").unbind("appendTo"); 
  53.                 }   
  54.             //如果按键是Backspace或者Delete 
  55.              
  56.             }else if(keycode == 46||keycode == 8){ 
  57.                 //如果输入框内容为空 
  58.                 if(m == ""){ 
  59.                     //删除最后一个li 
  60.                     var s = $(".tips_content ul li").length; 
  61.                     if(s>0){ 
  62.                         $(".tips_content ul li:last").remove().unbind(remove); 
  63.                     }     
  64.                 } 
  65.             } 
  66.         }); 
  67.         //为中文标点“逗号”单独设置的keyup事件 
  68.         $(this).keyup(function(){ 
  69.             var searchthis = $(this).val(); 
  70.             //如果val值存在中文逗号,即按下中文逗号,执行事件 
  71.             if(searchthis.indexOf(",") != -1){ 
  72.                 //正则表达式,全局搜索val值中的中文逗号 
  73.                 var resome = /,/g; 
  74.                 //将中文逗号替换为空,去除val值前后空格 
  75.                 searchthis = $.trim(searchthis.replace(resome,"")); 
  76.                 //给val返回处理完的值 
  77.                 $(this).val(searchthis); 
  78.                 //如果返回的值不为空 
  79.                 if(searchthis != ""){ 
  80.                     //添加li到ul 
  81.                     $("<li>"+searchthis+"<a>×</a></li>").appendTo(thisul); 
  82.                     //清空输入框 
  83.                     $(this).val("").unbind("appendTo"); 
  84.                 };     
  85.             }; 
  86.         }); 
  87.     //失去焦点时 
  88.     }).blur(function(){ 
  89.         //定义input的val值 
  90.         z = $(this).val(); 
  91.         //定义标签的个数 
  92.         licount = $(".tips_content li").length; 
  93.         //如果值为空 
  94.         if(z == ""){ 
  95.             //如果标签数为0 
  96.             if(licount == 0){ 
  97.                 //返回最初状态 
  98.                 $(this).val(thisval).css("color","#999"); 
  99.             }else{ 
  100.                 return false; 
  101.             }; 
  102.         //如果不为空 
  103.         }else{ 
  104.             //将此值变成标签 
  105.             $("<li>"+z+"<a>×</a></li>").appendTo(thisul); 
  106.             //清空输入框 
  107.             $(this).val("").unbind("appendTo"); 
  108.         } 
  109.     });     
  110. }); 
  111. </script> 
  112.  
  113. </head> 
  114.  
  115. <body> 
  116.     <div class="tips_content"> 
  117.         <ul></ul> 
  118.         <input type="text" size="5" style="border:none" />  
  119.     </div> 
  120. </body> 
  121. </html> 
 
 
有高手知道怎么传值给后台?
      本文转自许琴 51CTO博客,原文链接:http://blog.51cto.com/xuqin/1084827,如需转载请自行联系原作者
你可能感兴趣的文章
Java核心技术卷I基础知识3.5.3 强制类型转换
查看>>
可与Mirai比肩的恶意程序Hajime,竟是为了保护IoT设备?
查看>>
《Spring Data 官方文档》6. Cassandra 存储库
查看>>
聊聊并发(十)生产者消费者模式
查看>>
R语言数据挖掘2.2.4.2 FP-growth算法
查看>>
人工智能概念诞生60年,哪些大牛堪称“一代宗师”?
查看>>
《游戏大师Chris Crawford谈互动叙事》一9.5 真实案例
查看>>
Java Cache系列之Guava Cache实现详解
查看>>
设计模式 - 适配器
查看>>
CSS之可折叠导航
查看>>
淘宝美工设计师细说何为天猫透明背景
查看>>
【B/S学习总结】我的第100篇CSDN博客
查看>>
[Hadoop]chukwa与ganglia的区别
查看>>
数据挖掘工具分析北京房价 (一) 数据爬取采集
查看>>
IOS项目之弹出动画终结篇
查看>>
iOS开发UI篇—ios应用数据存储方式(XML属性列表-plist)
查看>>
OSS移动开发实战2 (30分钟快速搭建移动应用上传回调服务)
查看>>
Swift语言学习No.2: 二维数组
查看>>
Windows Azure初体验--功能介绍
查看>>
LEA 指令
查看>>