Javascript 放置<;a>;onclick div顶部的链接
我制作了一个内容磁贴,当点击时,会激活屏幕的另一部分。在互动程序上,我有几个链接,单击这些链接可以转到新页面。我制作了一个非javascript版本,效果很好 无javascript: HTML: 我想给它添加简单的动画,所以如果javascript可用,这个版本将加载 Javascript: Javascript:Javascript 放置<;a>;onclick div顶部的链接,javascript,html,css,Javascript,Html,Css,我制作了一个内容磁贴,当点击时,会激活屏幕的另一部分。在互动程序上,我有几个链接,单击这些链接可以转到新页面。我制作了一个非javascript版本,效果很好 无javascript: HTML: 我想给它添加简单的动画,所以如果javascript可用,这个版本将加载 Javascript: Javascript: document.addEventListener("DOMContentLoaded", setJavascriptTileAnimation(), false ); /*
document.addEventListener("DOMContentLoaded", setJavascriptTileAnimation(), false );
/* Set onclick events for tile animation
|
*/
function setJavascriptTileAnimation() {
var tiles = document.getElementsByClassName('tile')
var links = document.getElementsByClassName('noJavaLink');
for (var i = 0; i < tiles.length; i++) {
var tile = tiles[i];
var id = tile['id'];
tile.onclick = function() {
changeActiveTile(this.id);
//return false;
};
links[i].removeAttribute('href');
};
}
/* Toggle active tile
|
*/
function changeActiveTile(id) {
id_number = getIdNumber(id);
active_tile = document.getElementsByClassName('tile activeTile')[0];
active_tile.classList.remove('activeTile');
setTimeout(function() {
tile = document.getElementById(id);
tile.classList.add('activeTile');
}, 300);
}
function getIdNumber(id) {
return id.replace( /^\D+/g, '');
}
document.addEventListener(“DOMContentLoaded”,setJavaScriptiLeanimation(),false);
/*为平铺动画设置onclick事件
|
*/
函数setJavaScriptiLeanimation(){
var tiles=document.getElementsByClassName('tile')
var links=document.getElementsByClassName('noJavaLink');
对于(变量i=0;i
请注意,链接仅在双击时起作用。我已经玩了两天了,一点进展都没有。有什么想法吗
解决方案:从onclick setter中删除“return false”。调用
addEventListener
时,函数名后面不应有()
。这将立即调用该函数,而不是在事件发生时调用它。当我尝试使用小提琴时,它只需单击一次即可工作。@Barmar单击第二个链接就会弹出警报?在最新的beta chromeSorry中,我不认为你在谈论动画。@Barmar谢谢你的提示。对javascript还是很陌生。。。
.responseContainer {
position: relative;
overflow: hidden;
z-index: 0;
transition: all linear .2s;
border: 1px solid grey;
border-radius: 4px;
background-color: white;
}
.responseContainer p {
margin: 0;
}
.tile {
width: 80%;
text-align: left;
margin: 16px 48px 16px 32px;
margin-top: 0;
transition: all linear .2s;
z-index: 0;
border-radius: 4px;
background-repeat: no-repeat;
}
.activeTile {
width: 90%;
border-radius: 4px;
color: white;
}
.activeTile > div {
background-color: rgba(33, 33, 33, .5);
}
.left {
float: left;
margin: 10px;
margin-top: -10px;
max-width: 50%;
}
.title {
font-size: 1.2em;
}
.title h4 {
margin: 20px 0 20px;
}
.bonus {
float: right;
margin-top: 10px;
margin: 10px;
font-size: 1.5em;
max-width: 50%;
}
.topLink {
position: relative;
z-index: 100;
}
.noJavaLink {
position: absolute;
width: 100%;
height: 100%;
top: 0;
left: 0;
text-decoration: none;
z-index: 10;
background-color: white;
border-radius: 4px;
opacity: 0;
filter: alpha(opacity=0);
cursor: pointer;
}
.active .noJavaLink {
pointer-events: none;
cursor: default;
}
document.addEventListener("DOMContentLoaded", setJavascriptTileAnimation(), false );
/* Set onclick events for tile animation
|
*/
function setJavascriptTileAnimation() {
var tiles = document.getElementsByClassName('tile')
var links = document.getElementsByClassName('noJavaLink');
for (var i = 0; i < tiles.length; i++) {
var tile = tiles[i];
var id = tile['id'];
tile.onclick = function() {
changeActiveTile(this.id);
//return false;
};
links[i].removeAttribute('href');
};
}
/* Toggle active tile
|
*/
function changeActiveTile(id) {
id_number = getIdNumber(id);
active_tile = document.getElementsByClassName('tile activeTile')[0];
active_tile.classList.remove('activeTile');
setTimeout(function() {
tile = document.getElementById(id);
tile.classList.add('activeTile');
}, 300);
}
function getIdNumber(id) {
return id.replace( /^\D+/g, '');
}