Wagerfield'的例子看起来和来源不一样

Wagerfield's example looks different from source

本文关键字:看起来 不一样 Wagerfield      更新时间:2023-09-26

在设置parallax.js时,我遇到了以下问题:

html源标记(在官方的GIThub项目中)是:

    <ul id="scene" class="scene">
        <li class="layer" data-depth="1.00"><img src="images/layer1.png"></li>
        <li class="layer" data-depth="0.80"><img src="images/layer2.png"></li>
        <li class="layer" data-depth="0.60"><img src="images/layer3.png"></li>
        <li class="layer" data-depth="0.40"><img src="images/layer4.png"></li>
        <li class="layer" data-depth="0.20"><img src="images/layer5.png"></li>
        <li class="layer" data-depth="0.00"><img src="images/layer6.png"></li>
        </ul>

但是,如果我们看看(非常棒的)Wagerfield示例,它看起来像是作为每个.layer类元素内的div块的背景图像引入的。

我可以给自己的解释是,这样可以更灵活地控制图像,


我刚开始使用JS,所以我真的找不到解决方法:但是脚本不能转换这个

    <img src="images/layer1.png">

类似于:

    <div class="layer1" style="background:url(images/layer1.png) no-repeat 50% 100%"></div>

这能轻易实现吗?

扩展这个问题,用通过脚本传递的内联样式完全设置.layer的样式会很酷。

到目前为止的脚本:

     jQuery("li.layer > img").replaceWith
    ("<div class='"" + $((("li.layer > img").src).replace(/'.[^/.]+$/, "")) + "'"</div>" );

这部分不起作用(我正在寻找图像的url输出…):

    (("li.layer > img").src).replace(/'.[^/.]+$/, "")

这样的东西应该能起到作用。

$('#scene > .layer > img').replaceWith(function () { // select all images
    var s = this.src.substring(this.src.indexOf('images'), this.src.length);
    // get only the relative path of the url
    
  
    return $('<div/>', { // create a div
        class: s.replace(/'.[a-zA-Z]+/, '').split('/')[1], 
               // get the image name as class
        style: 'background:url(' + s + ') no-repeat 50% 100%' 
               // set style
    });
});
$('div').text(function(){
	return this.outerHTML;
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<ul id="scene" class="scene">
    <li class="layer" data-depth="1.00">
        <img src="images/layer1.png">
    </li>
    <li class="layer" data-depth="0.80">
        <img src="images/layer2.png">
    </li>
    <li class="layer" data-depth="0.60">
        <img src="images/layer3.png">
    </li>
    <li class="layer" data-depth="0.40">
        <img src="images/layer4.png">
    </li>
    <li class="layer" data-depth="0.20">
        <img src="images/layer5.png">
    </li>
    <li class="layer" data-depth="0.00">
        <img src="images/layer6.png">
    </li>
</ul>