放置<a> links on top of onclick div

时间:2015-04-30 00:48:33

标签: javascript html css

I made a content tile that when clicked, activates another part of the screen. On the tile, I have a couple links that, when clicked, go to new pages. I made a non-javascript version that works fine.

No javascript: https://jsfiddle.net/raazqqks/2/

HTML:

<div class="tile activeTile" id="response0">
    <div class="responseContainer">
        <div class="left">
            <h4 class="title">
                <a class="topLink" href="javascript:alert('Link clicked')">Title</a>
            </h4>
            <p>Foo bar</p>
            <p>Foo bar?</p>
            <p class="extra">
                <a class="topLink" href="javascript:alert('Link clicked')">Extra foo bar!</a>
            </p>
        </div>
        <div class="bonus">
            <p>Bonus</p>
        </div>
        <a class="noJavaLink" id="0" href="javascript:alert('Tile clicked');"></a>
    </div>
</div>

CSS:

.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;
}

我想为它添加简单的动画,所以如果javascript可用,则加载此版本。

使用Javascript: https://jsfiddle.net/n4svaLut/

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

请注意链接仅适用于双击。我已经玩了两天,并没有取得任何进展。有什么想法吗?

解决方案:从onclick setter中删除'return false'。

0 个答案:

没有答案