Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/473.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 放置<;a>;onclick div顶部的链接_Javascript_Html_Css - Fatal编程技术网

Javascript 放置<;a>;onclick div顶部的链接

Javascript 放置<;a>;onclick div顶部的链接,javascript,html,css,Javascript,Html,Css,我制作了一个内容磁贴,当点击时,会激活屏幕的另一部分。在互动程序上,我有几个链接,单击这些链接可以转到新页面。我制作了一个非javascript版本,效果很好 无javascript: HTML: 我想给它添加简单的动画,所以如果javascript可用,这个版本将加载 Javascript: Javascript: document.addEventListener("DOMContentLoaded", setJavascriptTileAnimation(), false ); /*

我制作了一个内容磁贴,当点击时,会激活屏幕的另一部分。在互动程序上,我有几个链接,单击这些链接可以转到新页面。我制作了一个非javascript版本,效果很好

无javascript:

HTML:

我想给它添加简单的动画,所以如果javascript可用,这个版本将加载

Javascript:

Javascript:

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, '');
}