jquery实现漂浮在网页右侧的qq在线客服插件示例


Posted in Javascript onMay 13, 2013

很实用的一款QQ在线客服代码,点击QQ图标,可直接与客服对话。具体实现代码如下:
html页面

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>jquery实现qq客服</title> 
<link rel="stylesheet" type="text/css" href="css/base.css"/> 
<script type="text/javascript" src="js/jquery-1.8.3.min.js"></script> 
<script type="text/javascript" src="js/qqservice.js"></script> 
<script type="text/javascript"> 
$(function(){ 
$("body").Sonline({ 
Position:"right",//left或right 
Top:200,//顶部距离,默认200px 
Effect:true, //滚动或者固定两种方式,布尔值:true或false 
DefaultsOpen:true, //默认展开:true,默认收缩:false 
Qqlist:"<SPAN>435027|客服01,435027|客服02,435027|客服03,435027|客服04,435027|客服05</SPAN>" //多个QQ用','隔开,QQ和客服名用'|'隔开 
}); 
}) 
</script> 
</head> 
<body> 
<div style="height:2500px"></div> 
<div style="text-align:center;clear:both"></div> 
</body> 
</html>

css样式
/*默认蓝色*/ 
.SonlineBox{ width:162px; font-size:12px;overflow:hidden; z-index:9999;} 
.SonlineBox .openTrigger{ width:30px; height:110px; position:absolute; top:0px; z-index:1; cursor:pointer; background:#0176ba url(../images/openTrigger.jpg) no-repeat;} 
.SonlineBox .titleBox{ width:158px; height:35px; line-height:35px; background:#038bdc url(../images/SonlineTitleBg.gif) repeat-x; border-bottom:2px solid #0176ba;} 
.SonlineBox .titleBox span{ margin-left:10px; color:#fff; font-size:14px; font-family:'微软雅黑','黑体';} 
.SonlineBox .contentBox{ width:158px; height:auto; border:2px solid #0176ba; background:#fff; position:absolute; z-index:2;} 
.SonlineBox .contentBox .closeTrigger{ width:25px; height:25px; display:block; cursor:pointer; position:absolute; top:5px;right:5px;-webkit-transition:all 0.8s ease-out;} 
.SonlineBox .contentBox .closeTrigger:hover{-webkit-transform:scale(1) rotate(360deg);} 
.SonlineBox .contentBox .listBox{overflow:hidden; margin-bottom:10px;} 
.SonlineBox .contentBox .listBox .QQList{ display:block; width:86%; height:22px; margin:10px auto 0px auto;} 
.SonlineBox .contentBox .listBox .QQList span{float:left; line-height:22px;} 
.SonlineBox .contentBox .listBox .QQList a{float:left;}

jquery脚本代码
/* 
此插件基于Jquery 
开发者 yaohucaizi 
Blog:http://blog.csdn.net/yaohucaizi/ 
*/ 
(function($){ 
$.fn.Sonline = function(options){ 
var opts = $.extend({}, $.fn.Sonline.defualts, options); 
$.fn.setList(opts); //调用列表设置 
if(opts.DefaultsOpen == false){ 
$.fn.Sonline.close(opts.Position,0); 
} 
//展开 
$("#SonlineBox > .openTrigger").live("click",function(){$.fn.Sonline.open(opts.Position);}); 
//关闭 
$("#SonlineBox > .contentBox > .closeTrigger").live("click",function(){$.fn.Sonline.close(opts.Position,"fast");}); //Ie6兼容或滚动方式显示 
if ($.browser.msie && ($.browser.version == "6.0") && !$.support.style||opts.Effect==true) {$.fn.Sonline.scrollType();} 
else if(opts.Effect==false){$("#SonlineBox").css({position:"fixed"});} 
} 
//plugin defaults 
$.fn.Sonline.defualts ={ 
Position:"left",//left或right 
Top:200,//顶部距离,默认200px 
Effect:true, //滚动或者固定两种方式,布尔值:true或 
DefaultsOpen:true, //默认展开:true,默认收缩:false 
Qqlist:"" //多个QQ用','隔开,QQ和客服名用'|'隔开 
} 
//展开 
$.fn.Sonline.open = function(positionType){ 
var widthValue = $("#SonlineBox > .contentBox").width(); 
if(positionType=="left"){$("#SonlineBox > .contentBox").animate({left: 0},"fast");} 
else if(positionType=="right"){$("#SonlineBox > .contentBox").animate({right: 0},"fast");} 
$("#SonlineBox").css({width:widthValue+4}); 
$("#SonlineBox > .openTrigger").hide(); 
} 
//关闭 
$.fn.Sonline.close = function(positionType,speed){ 
$("#SonlineBox > .openTrigger").show(); 
var widthValue =$("#SonlineBox > .openTrigger").width(); 
var allWidth =(-($("#SonlineBox > .contentBox").width())-6); 
if(positionType=="left"){$("#SonlineBox > .contentBox").animate({left: allWidth},speed);} 
else if(positionType=="right"){$("#SonlineBox > .contentBox").animate({right: allWidth},speed);} 
$("#SonlineBox").animate({width:widthValue},speed); 
} 
//子插件:设置列表参数 
$.fn.setList = function(opts){ 
$("body").append("<div class='SonlineBox' id='SonlineBox' style='top:-600px;'><div class='openTrigger' style='display:none' title='展开'></div><div class='contentBox'><div class='closeTrigger'><img src='images/closeBtnImg.gif' title='关闭' /></div><div class='titleBox'><span>客服中心</span></div><div class='listBox'></div></div></div>"); 
if(opts.Qqlist==""){$("#SonlineBox > .contentBox > .listBox").append("<p style='padding:15px'>暂无在线客服。</p>")} 
else{var qqListHtml = $.fn.Sonline.splitStr(opts);$("#SonlineBox > .contentBox > .listBox").append(qqListHtml); } 
if(opts.Position=="left"){$("#SonlineBox").css({left:0});} 
else if(opts.Position=="right"){$("#SonlineBox").css({right:0})} 
$("#SonlineBox").css({top:opts.Top}); 
var allHeights=0; 
if($("#SonlineBox > .contentBox").height() < $("#SonlineBox > .openTrigger").height()){ 
allHeights = $("#SonlineBox > .openTrigger").height()+4; 
} else{allHeights = $("#SonlineBox > .contentBox").height()+4;} 
$("#SonlineBox").height(allHeights); 
if(opts.Position=="left"){$("#SonlineBox > .openTrigger").css({left:0});} 
else if(opts.Position=="right"){$("#SonlineBox > .openTrigger").css({right:0});} 
} 
//滑动式效果 
$.fn.Sonline.scrollType = function(){ 
$("#SonlineBox").css({position:"absolute"}); 
var topNum = parseInt($("#SonlineBox").css("top")+""); 
$(window).scroll(function(){ 
var scrollTopNum = $(window).scrollTop();//获取网页被卷去的高 
$("#SonlineBox").stop(true,true).delay(0).animate({top:scrollTopNum+topNum},"slow"); 
}); 
} 
//分割QQ 
$.fn.Sonline.splitStr = function(opts){ 
var strs= new Array(); //定义一数组 
var QqlistText = opts.Qqlist; 
strs=QqlistText.split(","); //字符分割 
var QqHtml="" 
for (var i=0;i<strs.length;i++){ 
var subStrs= new Array(); //定义一数组 
var subQqlist = strs[i]; 
subStrs = subQqlist.split("|"); //字符分割 
QqHtml = QqHtml+"<div class='QQList'><span>"+subStrs[1]+":</span><a target='_blank' href='http://wpa.qq.com/msgrd?v=3&uin="+subStrs[0]+"&site=qq&menu=yes'><img border='0' src='http://wpa.qq.com/pa?p=2:"+subStrs[0]+":41 &r=0.22914223582483828' alt='点击这里'></a></div>" 
} 
return QqHtml; 
} 
})(jQuery);

效果图如下:
jquery实现漂浮在网页右侧的qq在线客服插件示例
Javascript 相关文章推荐
javaScript 读取和设置文档元素的样式属性
Apr 14 Javascript
js 跨域和ajax 跨域问题小结
Jul 01 Javascript
jQuery对表单元素的取值和赋值操作代码
May 19 Javascript
jquery处理json数据实例分析
Jun 03 Javascript
Js实现滚动变色的文字效果
Jun 16 Javascript
JavaScript 性能优化小结
Oct 12 Javascript
js实现n秒倒计时后才可以点击的效果
Dec 20 Javascript
javascript+HTML5自定义元素播放焦点图动画
Feb 21 Javascript
浅谈Vue.js 组件中的v-on绑定自定义事件理解
Nov 17 Javascript
vue2中,根据list的id进入对应的详情页并修改title方法
Aug 24 Javascript
在小程序Canvas中使用measureText的方法示例
Oct 19 Javascript
详解ES6 CLASS在微信小程序中的应用实例
Apr 24 Javascript
js 程序执行与顺序实现详解
May 13 #Javascript
JS/jQuery实现默认显示部分文字点击按钮显示全部内容
May 13 #Javascript
JS 加入收藏夹的代码(主流浏览器通用)
May 13 #Javascript
jQuery实现长文字部分显示代码
May 13 #Javascript
jq选项卡鼠标延迟的插件实例
May 13 #Javascript
jQuery获取CSS样式中的颜色值的问题,不同浏览器格式不同的解决办法
May 13 #Javascript
怎么清空javascript数组
May 11 #Javascript
You might like
PHP中防止SQL注入攻击和XSS攻击的两个简单方法
2010/04/15 PHP
PHP对称加密函数实现数据的加密解密
2016/10/27 PHP
php中10个不同等级压缩优化图片操作示例
2016/11/14 PHP
发现的以前不知道的函数
2006/09/19 Javascript
用jQuery扩展自写的 UI导航
2010/01/13 Javascript
JQuery中getJSON的使用方法
2010/12/13 Javascript
基于jquery的点击链接插入链接内容的代码
2012/07/31 Javascript
js中replace的用法总结
2013/12/27 Javascript
JS数组的赋值介绍
2014/03/10 Javascript
谈一谈jQuery核心架构设计
2016/03/28 Javascript
简单了解JavaScript操作XPath的一些基本方法
2016/06/03 Javascript
使用Require.js封装原生js轮播图的实现代码
2017/06/15 Javascript
JavaScript实现的数字与字符串转换功能示例
2017/08/23 Javascript
快速理解 JavaScript 中的 LHS 和 RHS 查询的用法
2017/08/24 Javascript
详解Vue SSR( Vue2 + Koa2 + Webpack4)配置指南
2018/11/13 Javascript
vue使用Google地图的实现示例代码
2018/12/19 Javascript
Vue中使用Lodop插件实现打印功能的简单方法
2019/12/19 Javascript
ES2020 已定稿,真实场景案例分析
2020/05/25 Javascript
简洁的十分钟Python入门教程
2015/04/03 Python
离线安装Pyecharts的步骤以及依赖包流程
2020/04/23 Python
django2.0扩展用户字段示例
2019/02/13 Python
利用Python脚本实现自动刷网课
2020/02/03 Python
布鲁明戴尔百货店:Bloomingdale’s
2016/12/21 全球购物
印度最大的时尚购物网站:Myntra
2018/09/13 全球购物
Dr. Martens马汀博士法国官网:马丁靴鼻祖
2020/01/15 全球购物
高中自我鉴定范文
2013/11/03 职场文书
大学生文员专业个人求职信范文
2014/01/05 职场文书
结婚典礼证婚词
2014/01/11 职场文书
如何写好优秀的创业计划书
2014/01/30 职场文书
乡镇党员干部四风对照检查材料思想汇报
2014/09/27 职场文书
邀请函怎么写
2015/01/30 职场文书
《神奇的鸟岛》教学反思
2016/02/22 职场文书
如何写好开幕词?
2019/06/24 职场文书
Vue-Element-Admin集成自己的接口实现登录跳转
2021/06/23 Vue.js
教你使用Python获取QQ音乐某个歌手的歌单
2022/04/03 Python
python字符串的一些常见实用操作
2022/04/06 Python