慕课-tooltip提示框总结
在慕课上学Waynej老师的tooltip浮动提示框,老师每次讲课都会强调搬砖的流程,这点在上了老师的几节课后宝宝终于体会到了:
分析→设计→编码→优化
分析:分析该功能到底是怎样的,其实就是需求分析,具体可通过演示过程来知道;
设计:分析实现以上功能需要的技术点,详细落实html,css和js部分,分析代码结构,形成大致的样子
编码:搬砖
优化:对缩写的代码分析优化(tooltip案例中主要是缩写重复使用的方法;一些经常使用到的元素提前定义好,免得每次用都去获取一次Dom;还有就是冒泡绑定事件(避免多个事件添加到子元素,可将一些相同的方法绑定到父元素然后冒泡处理;其次冒泡允许多个操作被集中处理))
好了现在是具体哒
判断IE浏览器:
| var isIE = navigator.useAgent.indexOf('MSIE')>=0; |
但是以上方法不能判定是否是IE11,综合能判断包括IE11的代码如下:
| var isIEeleven = navigator.useAgent.indexOf('Trident') >= 0 && navigator.useAgent.indexOf('rv:11') >=0; |
判断IE8-10的如下:
| vavigator.useAgent.indexOf('MSIE') >=0 && vavigator.useAgent.indexOf('Trident') >=0; |
判断IE6-7的如下:
| vavigator.useAgent.indexOf('MSIE') >=0; |
顺手总结一下好了,上代码:
function browser(){
var ua=window.navigator.userAgent;
//*****检测IE*****//
//检测Trident引擎,IE8+
if(/Trident/.test(ua)){
//IE11+
if(/rv:(\d+)/.test(ua)){
alert('IE11');
}
//IE8-IE10
if(/MSIE (\d+)/.test(ua)){
alert('IE8-10');
}
}
//检测IE标识,IE7-
if(/MSIE (\d+)/.test(ua)){
alert('IE7-');
}
//*****检测chrome*****//
if(!/OPR/.test(ua)){
if(/Chrome\/(\S+)/.test(ua)){
alert('chrome');
}
}
//*****检测Safari*****//
//需先排除opera
if(!/OPR/.test(ua)){
//检测出chrome和safari浏览器
if(/Safari/.test(ua)){
//检测出safari
if(/Version\/(\S+)/.test(ua)){
alert('safari');
}
}
}
//*****检测Firefox*****//
if(/Firefox\/(\S+)/.test(ua)){
alert('firefox');
}
//*****检测opera*****//
if(/OPR\/(\S+)/.test(ua)){
alert('opera');
}
}
browser();
关于识别浏览器内核、版本还有操作系统、移动端设备的,详细可查看:http://www.cnblogs.com/xiaohuochai/p/4822001.html?utm_source=tuicool&utm_medium=referral 在此跪谢作者,嘻嘻~
统一绑定事件的方法:
function addEvent(element ,event ,callbackFunction){
if(elemen . addEventListener){
element.addEventListener(event , callbackFunction,false);
}
//IE
else if (element . attachEvent){
element . attachEvent('on' + event , callbackFunction);
}
}
addEvent(element , 'event' ,function( e ){
//获取event对象,其他浏览器可通过e这样一个参数来获取,而IE需要window.event
var event = e || window.event ;
//获取触发事件的源,IE不支持target
var target=event.target || evnet.srcElement
......
});
关于jQuery中 .bind \ .live\ .delegate 绑定事件:
不过从jQuery1.7开始把这些合并成了on()方法,unbind\die\undelegate合并成了 off();
bind只能对已有元素绑定,而且是直接绑定在元素上,对未来的元素不起作用,而live和delegate是通过冒泡法绑定的且能对后续新增的元素起作用;
live 和delegate的区别,看下面的例子:
$('a').live('click', function() { .... });
$(document).delegate('a', 'click', function() { .... });
实际上后者会快于前者,前者要扫描整个文档查找$('a')元素并将之存储为jQuery对象,而delegate仅需要查找并存在$('delegate')元素;所以一般更倾向于用delegate
还有几个
setTimeout:在指定毫秒数后执行函数或表达式,且只执行一次 ; 若需多次执行,应使用setInterval() 或者让code本身再次调用setTimeout,此时需要停止的话就分别用
clearInterval和clearTimeout ;
setInterval : 按指定周期来执行函数或表达式;而clearInterval()是用于取消setInterval的,一般这么用:
|
var timer=setInterval( function(){ ...... }); clearInterval(timer); |
onmouseenter和onmouseover的区别,onmouseover穿过其子元素也会触发事件,而onmouseenter不会;同理onmouseleave和onmouseout;
/*****ok , 理论上整理完毕~madamada danei*****/
话说真的好久好久好久木有撸代码了,从元旦收假后就一直在准备期末考试,十多天得时间,一学期了有的书我都没拆封的 = =。。差点残了。。。。理论上应该还是不会挂的;13号晚上到的家,哦嚯嚯~愉快搬砖
慕课-tooltip提示框总结的更多相关文章
- 纯CSS实现tooltip提示框,CSS箭头及形状之续篇--给整个tooltip提示框加个边框
在前面一篇中我们介绍了纯CSS实现tooltip提示框,通俗的讲也就是CSS箭头及形状 不过注意一点是,他始终是一个元素,只是通过CSS实现的,今天我们要说的是给这个“tooltip提示框”整体加一个 ...
- 使用css实现全兼容tooltip提示框
在上一篇文章中,使用css实现了一个全兼容的三角形图标,这个三角型图标可以使用于多种场景,比如下拉图标.多级菜单等,这篇文章我们使用这个图标通过纯css来实现一个我们常见的tooltip提示框. 最终 ...
- CSS3实现Tooltip提示框飞入飞出动画
原文:CSS3实现Tooltip提示框飞入飞出动画 我们见过很多利用背景图片制作的Tooltip提示框,但是缺点是扩展比较麻烦,要经常改动图片.还有就是利用多层CSS的叠加实现,但是效果比较生硬,外观 ...
- Echarts数据可视化tooltip提示框,开发全解+完美注释
全栈工程师开发手册 (作者:栾鹏) Echarts数据可视化开发代码注释全解 Echarts数据可视化开发参数配置全解 6大公共组件详解(点击进入): title详解. tooltip详解.toolb ...
- echarts中tooltip提示框位置控制
关键代码: position: function(point, params, dom, rect, size) { //其中point为当前鼠标的位置,size中有两个属性:viewSize和con ...
- MFC中添加ToolTip提示框
PART 1 MFC 对话框中的 Buttton添加提示 例如我们想在一个对话框中的一个button控件添加tooltip,实现的方法如下: 1. 在该对话框的类中添加一个CToolTipCtrl类型 ...
- tooltip提示框组件
Tooltip 提示框组件 可独立于其他组件通过$.fn.tooltip.defaults重写默认的defaults.当用户移动鼠标指针在某个元素上时,出现提示信息窗口来显示额外信息.提示内容可以包含 ...
- 第一百九十六节,jQuery EasyUI,Tooltip(提示框)组件
jQuery EasyUI,Tooltip(提示框)组件 学习要点: 1.加载方式 2.属性列表 3.事件列表 4.方法列表 本节课重点了解 EasyUI 中 Tooltip(提示框)组件的使用方法, ...
- echarts自定义tooltip提示框内容
1.echarts自定义tooltip提示框内容 https://blog.csdn.net/dreamsup/article/details/56667330 2.关于Echarts的formatt ...
随机推荐
- 3.创建线程的第二种写法,继承threading.Tread类,重写run方法
#创建线程的第二种写法 #1.自定义一个类 #2.继承Thread #3.重写run()方法 import threading,time,random class MyThread(threading ...
- 《JAVA设计模式》之建造模式(Builder)
在阎宏博士的<JAVA与模式>一书中开头是这样描述建造(Builder)模式的: 建造模式是对象的创建模式.建造模式可以将一个产品的内部表象(internal representation ...
- (三)Schema与数据类型优化
1.Schema schema,中文叫模式,是数据库的组织和结构 2.选择优化的数据类型 更小的通常更好:尽量使用可以正确存储数据的最小数据类型 简单就好:简单数据类型的操作通常需要更少的cpu周期. ...
- java_第一年_JavaWeb(8)
前面说到,JSP在运行时会被编译成Servlet源代码,通过_jspServlet方法处理请求,此时该方法会传递和提供9个与web开发相关的对象进行使用,开发人员在JSP页面通过对这些变量即可引用这9 ...
- php cookie session 深究一下
当一个用户用浏览器访问web(www.96net.com.cn)时候,若服务器开启session_start() 服务器tmp临时目录 自动生成session_id 并放回给创建一个cookie 保存 ...
- Go语言_更多类型:struct、slice 和映射
更多类型:struct.slice 和映射 学习如何基于现有类型定义新的类型:本节课涵盖了结构体.数组.切片和映射. Go 作者组编写,Go-zh 小组翻译. https://tour.go-zh.o ...
- 手模手配置Eslint,看懂脚手架中的Eslint
使用ESLint前:eslint是干嘛的,我这样写有什么问题,怎么还报错了,太麻烦想去掉这个插件,脚手架中关于eslint文件里的配置是什么意思?怎么设置配置项和规则达到自己想要的检测效果呢?怎么集成 ...
- mpvue中的平台状态判断(H5网页 or 小程序)
在开发微信小程序或者微信网页H5的时候,有时我们利用外部组件可能不兼容这两者,需要区分开来,可以在对应的mainjs中配置如下 let platform: try{ if(wx){ platform= ...
- 【学术篇】bzoj2440 [中山市选2011]完全平方数
-题目の传送门- 题目大意: 找到第k个无平方因子数. 看到数据范围很大, 我们要采用比\(O(n)\)还要小的做法. 考虑如果前\(x\)个数中有\(k-1\)个无平方因子数, 而前\(x+1\)个 ...
- HTML5 canvas绘制图片
demo.js window.onload=function() { createcanvas(); drawImage(); } function createcanvas() { var CANV ...