完美实现仿QQ空间评论回复特效


Posted in Javascript onMay 06, 2015

评论回复是个很常见的东西,但是各大网站实现的方式却不尽相同。大体上有两种方式

1.

完美实现仿QQ空间评论回复特效

像优酷这种最常见,在输入框中@要回复的人,这种方式下,用户可以修改@。

新浪微博则是在这个基础上,弹出好友菜单。这种方式的好处是不需要任何js,css处理兼容。

完美实现仿QQ空间评论回复特效

2.

完美实现仿QQ空间评论回复特效

像qq空间这种,对回复的人整个删除。本?鸥芯跽庵址绞奖冉虾茫??庵址绞接行┘嫒菪陨系南附冢?飧龊竺婊嵯晗杆得鳌?/p>

事实上,qq空间的这种实现在效果上是兼容了ie和现代浏览器的,做的非常好。上面是chrome

ie8

完美实现仿QQ空间评论回复特效

ie7

完美实现仿QQ空间评论回复特效

ie6就不上图片了,太卡了,都懂得,最后本?呕岣缴献钪绽?拥模?比灰布嫒?e6。

下面就说说怎么实现的。

先看看qq空间是怎么做的

chrome

完美实现仿QQ空间评论回复特效

上面可以看到,qq空间是在button中加上文字,这样在删除的时候对被回复的用户名就能整个删除了。

不过这样做还不够,首先是样式,需要把button设置成inline-block,

消除button默认的透明背景,边框,当然还有padding,margin设为0

button{ border: 0; background:none; }

这时在ie6,7中插入会发现,似乎还存在padding,而且还很大

完美实现仿QQ空间评论回复特效

完美实现仿QQ空间评论回复特效

所以还需要加上overflow: visible;

另外属性contenteditable设置成为false,否则光标会跳到button里面,

然后在ie8下会发现,输入的时候如果有回车,然后在依次删除的过程中,会发现button标签删不掉,光标会跑到button标签前面,而且再次按右光标键或用鼠标点击button标签右边都无法让光标跑到button标签右边。事实上,qq空间在ie8中也有这个问题

ie8

完美实现仿QQ空间评论回复特效

而在ie6,7下,就没有这个问题

ie7

完美实现仿QQ空间评论回复特效

ie6

完美实现仿QQ空间评论回复特效

这里针对ie8需要对文本框绑定keydown事件回调check_comment,对ie6,7绑定了也没有问题,这里就统一的对ie绑定。

function getPositionForTextArea(ctrl) { //获取光标位置
      var CaretPos = 0; 
      if(document.selection) {
        ctrl.focus(); 
        var Sel = document.selection.createRange(); 
        var Sel2 = Sel.duplicate(); 
        Sel2.moveToElementText(ctrl); 
        var CaretPos = -1; 
        while(Sel2.inRange(Sel)){ 
          Sel2.moveStart('character'); 
          CaretPos++; 
        } 
      }else if(ctrl.selectionStart || ctrl.selectionStart == '0'){
        CaretPos = ctrl.selectionStart; 
      } 
      return (CaretPos); 
    }
      vm.check_comment=function(e,i){
        var a=getPositionForTextArea($('reply'+i));
        if(e.keyCode==8&&a<3){
          var pat = new RegExp("^<p><button .*?>.*?</button> </p>$",'i');
          if(pat.test(this.innerHTML))
            this.innerHTML='';
        }
      };

光标位置<3表明光标前面就是button标签了,这时就可以清空输入框了。注意这里为了严谨,用正则表达式验证是不是button标签.

另外在正则表达式中button标签外包裹p标签,是因为ie在按回车换行时,会默认自动对前面的行包裹p标签。当然,一开始在输入框也要在button标签外包裹p标签。

完美实现仿QQ空间评论回复特效

题外话

qq空间在ff上用的是img标签

完美实现仿QQ空间评论回复特效

之前一直以为qq空间在现代浏览器上统一用的是img标签,写的时候才发现在chrome中用的是button标签,于是就在chrome下试了一下插入img标签,发现怎么也弄不掉边框,而且删除的时候,绑定中光标位置的判断也会和ie不一致,因为现代浏览器换行默认插入<br>,于是索性对chrome也用button标签。

另外在我的例子中,ff中插入button标签的话,输入框不容易获得焦点。本?乓怖恋萌ジ牧?仍然是在ff中插入img标签,对应的keydown回调

if(!!-[1,]&&e.keyCode==8&&$('reply'+i).childNodes.length==2){//ff
          this.innerHTML='';
          return;
        }

只用判断输入框的子节点个数就可以了。

最终效果

chrome

完美实现仿QQ空间评论回复特效

ff

完美实现仿QQ空间评论回复特效

ie8

完美实现仿QQ空间评论回复特效

ie7

完美实现仿QQ空间评论回复特效

ie6

完美实现仿QQ空间评论回复特效

附上例子下载

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
Javascript 中的类和闭包
Jan 08 Javascript
js 蒙版进度条(结合图片)
Mar 10 Javascript
firefox火狐浏览器与与ie兼容的2个问题总结
Jul 20 Javascript
点击按钮或链接不跳转只刷新页面的脚本整理
Oct 22 Javascript
深入理解javascript的执行顺序
Apr 04 Javascript
JS实现的全排列组合算法示例
Oct 09 Javascript
vue 项目如何引入微信sdk接口的方法
Dec 18 Javascript
JS简单添加元素新节点的方法示例
Feb 10 Javascript
vue数组对象排序的实现代码
Jun 20 Javascript
jQuery实现的简单手风琴效果示例
Aug 29 jQuery
vue实现Excel文件的上传与下载功能的两种方式
Jun 28 Javascript
vue简单练习 桌面时钟的实现代码实例
Sep 19 Javascript
jQuery实现鼠标单击网页文字后在文本框显示的方法
May 06 #Javascript
js实现点击按钮后给Div图层设置随机背景颜色的方法
May 06 #Javascript
JS实现CheckBox复选框全选全不选功能
May 06 #Javascript
javascript使用avalon绑定实现checkbox全选
May 06 #Javascript
js实现滑动触屏事件监听的方法
May 05 #Javascript
JS根据生日算年龄的方法
May 05 #Javascript
js改变Iframe中Src的方法
May 05 #Javascript
You might like
开启CURL扩展,让服务器支持PHP curl函数(远程采集)
2011/03/19 PHP
PHP 之 写时复制介绍(Copy On Write)
2014/05/13 PHP
ThinkPHP实现动态包含文件的方法
2014/11/29 PHP
IE浏览器PNG图片透明效果代码
2008/09/02 Javascript
ExtJS Window 最小化的一种方法
2009/11/18 Javascript
JQuery 常用方法和事件详细介绍
2013/04/18 Javascript
JavaScript返回网页中超链接数量的方法
2015/04/03 Javascript
javascript三元运算符用法实例
2015/04/16 Javascript
JS实现的不规则TAB选项卡效果代码
2015/09/18 Javascript
Bootstrap每天必学之简单入门
2015/11/19 Javascript
javascript模块化简单解析
2016/04/07 Javascript
js中遍历对象的属性和值的方法
2016/07/27 Javascript
jQuery实现联动下拉列表查询框
2017/01/04 Javascript
JS html时钟制作代码分享
2017/03/03 Javascript
vue + socket.io实现一个简易聊天室示例代码
2017/03/06 Javascript
ES6入门教程之Class和Module详解
2017/05/17 Javascript
基于webpack 实用配置方法总结
2017/09/28 Javascript
vue+elementUI实现图片上传功能
2019/08/20 Javascript
layer弹出层自适应高度,垂直水平居中的实现
2019/09/16 Javascript
LayUi数据表格自定义赋值方式
2019/10/26 Javascript
Javascript如何递归遍历本地文件夹
2020/08/06 Javascript
numpy中矩阵合并的实例
2018/06/15 Python
深入理解Django-Signals信号量
2019/02/19 Python
PyTorch之图像和Tensor填充的实例
2019/08/18 Python
python list等分并从等分的子集中随机选取一个数
2020/11/16 Python
写clone()方法时,通常都有一行代码,是什么?
2012/10/31 面试题
工程项目经理岗位职责
2013/12/15 职场文书
敬老文明号事迹材料
2014/01/16 职场文书
大学生怎样写好自荐信
2014/02/25 职场文书
婚礼新人答谢词
2015/01/04 职场文书
公司晚宴祝酒词
2015/08/11 职场文书
团队执行力培训心得体会
2015/08/15 职场文书
2019学校请假条格式及范文
2019/06/25 职场文书
导游词之平津战役纪念馆
2019/11/04 职场文书
导游词之秦皇岛燕塞湖
2020/01/03 职场文书
Win10多屏显示如何设置?Win10电脑多屏显示设置操作方法
2022/07/07 数码科技