JS—杂章

字符串"true"、"false"转布尔型的true、false

//函数方法
function strToBoolean (str){
  return str === 'true' ;  //换成boolean
}
console.log(strToBoolean("true")); //打印为true

//改变String的原型
String.prototype.bool = function() { 
  return (/^true$/i).test(this); 
}; 
console.log("true".bool()); //打印为true

mouseup事件丢失的原因与解决办法

本方法引自:https://www.jb51.net/article/116164.htm

原因描述:
1.触发了浏览器的 drag 操作,导致mouseup丢失。
2.由于鼠标离开了操作的区域,触发了mouseleave导致mouseup丢失。

  • 第一种原因解决方法:通过对事件调用pauseEvent方法可以防止出现drag操作,因此在区域内可以避免mouseup丢失。即使你想实现的本来就是 drag 操作,也可以通过创建跟随鼠标移动的dom元素实现效果。
//在事件中
e=e || window.event;
pauseEvent(e);

//阻止事件冒泡
//不仅仅要stopPropagation,还要preventDefault
function pauseEvent(e){
 if(e.stopPropagation) e.stopPropagation();
 if(e.preventDefault) e.preventDefault();
 e.cancelBubble=true;
 e.returnValue=false;
 return false;
}
  • 第二种原因解决方法:由于鼠标移到了区域外,触发了 mouseleave 操作,因此在这种情况下要监听 mouseleave 操作,当触发该操作时可以停止或者还原状态。

当处理鼠标事件时,可以还要考虑是否要控制按下那个键时才允许操作。
Mouse事件中有一个 buttons 属性,该值标示鼠标按下了一个或者多个按键,如果按下的键为多个,值则为多个:

  0 : 没有按键或者是没有初始化
  1 : 鼠标左键
  2 : 鼠标右键
  4 : 鼠标滚轮或者是中键
  8 : 第四按键 (通常是“浏览器后退”按键)
  16 : 第五按键 (通常是“浏览器前进”)

多个值的时候,相当于进行|操作,即鼠标左右键同时按下时1|2=3。判断是否按下左键可以用value&1!=0进行,例如左右键同时按下时3&1!=0是true,说明按下了左键。


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。