js中li .active不能实现效果而li.active可以实现效果

 我来答
xiangjuan314
2016-04-16 · TA获得超过3.3万个赞
知道大有可为答主
回答量:2.9万
采纳率:0%
帮助的人:2921万
展开全部
/* 普通效果 */
.x_list li {
padding: 3px;
width: 100%;
list-style: none;
background-color: #999;/*普通效果的背景色*/
border-bottom: 1px solid #333;
border-top: 1px solid white;
clear: both;
display: inline-table;
position: relative;
}
/* 点击效果 */
.x_list li:active{
background-color:red;
}

看来,hover 与 active 意思虽相近,但细作起来还是明显差别。以往讨论桌面的时候,大多用 hover 即可,而现如今在手机上却把两者的区别给凸显出来了。我想,这是什么缘故呢,——为什么以往桌面的做法行得通,而手机上却把问题暴露出来呢。我觉得,执行“事件的媒介”也是重要的原因,因为桌面上输入事件的乃鼠标器居多,而且手机上则围绕手指触控的居多。两者的分野,导致所处于的经验与法则也不尽相同。可以说,承接下来的那个 bug,都有同样的缘故在作祟。
可是,即使使用 active,又遇到浏览器支持的问题:——Android 2.x 仍不支持元素:active,新版的 Android 4.x 和 iOS 则顺利通过。于是我安排 iOS 与 Android 4 就用 CSS 的写法,而 Android 另一边厢安排 js 方法实现之。

既然用 js 方法实现之,我第一时间想到的用 setTimeout() 定时器实现之。点击后添加一样式,timeout 之后撤销样式。

[javascript] view plain copy
// 用户按下之后,为元素加入高亮样式,然后立刻消褪,——这就是所谓的 active 样式。
// 请注意,这个方法属于“反面教材”
function onActive(el, fn){
el.addCls('active');
setTimeout(function(){
fn && fn();
el.removeCls('active');
}, 300);
}

这个貌似可行的办法实则不正确!因为经过领导演示,人家 Sencha Touch 的选中高亮是可以跟随滚动的,我的在首页上的点击高亮是可以但不会响应点击滚动,有反常理!甚幸,恰恰有正确的案例在前,让我可以参照,可以纠正。后来结果通过 touchstart/touchend 事件实现这个界面触控效果。代码如下:

[javascript] view plain copy
HTMLElement.prototype.onActive = (function () {
/**
* this 应为 CSS Selector
* @param {Event} e
*/
function highlight(e){
var targetEl = e.target;
if(targetEl && targetEl.tagName == this.toUpperCase()){
targetEl.toggleCls('active');
}else if(targetEl){
arguments.callee.call(this, {
target : targetEl.parentNode
});
}
}

// 是否支持触摸事件
var isSupportTouch = 'ontouchstart' in window || "ontouchend" in window.document;
// 支持触摸式使用相应的事件替代
var hightEvent_in = isSupportTouch ? 'touchstart': 'mouseover',
hightEvent_out = isSupportTouch ? 'touchend' : 'mouseout';

/**
* @param {String} highlightCfg
*/
return function(el_cssSelector){
// ONLY FOR Moblie?
if (!window.navigator.isAndroid_2) {
return false;
}
var eventHandler = highlight.bind(el_cssSelector || 'LI'); // 默认 li 修改样式
// $$.addListener 为跨浏览器的事件添加器
$$.addListener(this, hightEvent_in, eventHandler);
$$.addListener(this, hightEvent_out, eventHandler);
// $$.addListener(this, 'touchcancel',eventHandler, isUseCapture); /*@todo考察该事件,比较特殊*/
return this; // 方便链式调用
}
})();
上述代码扩展的浏览器原生对象 HTMLElment 原型,因此在任一元素身上都有 onActive 方法,另外 toggleCls(className) 也是通过扩展元素原型来提供的。相应地,样式不经过伪类来实现,而是定义一个 .active 的样式类:

[css] view plain copy
/* 点击效果 */
.x_list li.active{ /* 注意这里冒号被改为点号*/
background-color:red;
}
函数 highlight 中,因为登记事件时不能触发 userCapture,所以没有使用“事件冒泡”的方式而是递归上报的方式。
2013-4-7 重新整理一下这个函数,请注意这是没有版本检测,你应该自己加一个,因为只针对 android 2.x。

[javascript] view plain copy
/**
* 模拟 el:active
* @param {Element} ul 参数为元素
*/
function onActive(ul){
// ONLY FOR Android 2.x? Yes!
// 检测是否 android 2.x 的属性,你可以依赖你自己的方案,我的就不贴了,比较简单的。
// if (!window.navigator.isAndroid_2) {
// return ul; //尽管该函数不工作,也要返回 this,以方便链式调用
// }

// add Highlight
ul.addEventListener('touchstart', function (e){
var targetEl = e.target;
while(targetEl && targetEl.tagName != 'LI'){// 默认为 li 修改样式
targetEl = targetEl.parentNode; // 找到要操作的目标元素为止
}
// do sth……
console.log(targetEl.tagName);
targetEl.addCls('active');
});

// remove Highlight
ul.addEventListener('touchend', function (e){
var targetEl = e.target;
while(targetEl && targetEl.tagName != "LI"){
targetEl = targetEl.parentNode; // 找到要操作的目标元素为止
}
// do sth……
console.log(targetEl.tagName);
targetEl.removeCls('active');
});

return ul; // 方便链式调用
}

CSS 样式如下:
[css] view plain copy
/* 点击效果 */
ul.x_list li:active, ul.x_list li.active {
background-image: -webkit-gradient(linear, center top, center bottom, from(lightGrey), to(white));
}
2013-04-18 把问题重新整理了一下,给出如下“药方”:

[html] view plain copy
<style type="text/css">
p:active, p.active{
background-color:red;
}
</style>
<body>
<p>Welcome to Jdrop
Jdrop provides a place to store JSON data in the cloud. The initial application is for storing performance data gathered from mobile devices. It's hard to analyze large amounts of information (HTTP waterfall charts, HTTP headers, document source, etc.) on a mobile device. Jdrop lets you gather this data on the mobile device but analyze it remotely on a larger screen. </p>
</body>
<script type="text/javascript">
document.addEventListener('touchstart', function (e) {
e.target.className = 'active';
}, false);
document.addEventListener('touchend', function (e) {
e.target.className = '';
}, false);
</script>
追问
不懂
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式