开发者社区> 问答> 正文

div.style.left="600px"怎么不起作用?

用原生js控制div向左移动600px,不起作用。已经设置父元素position:relative,
当前元素position:absolute,即使已经设置

即内联样式也不起作用。
代码如下:
<div class="stage" >
    <span class="prev arrow">&lt;</span>
    <span class="next arrow">&gt;</span>
    <div class="wrap" style="left:-600px">
        <img src="img/1.jpg" alt="1">
        <img src="img/1.jpg" alt="2">
        <img src="img/2.jpg" alt="3">
        <img src="img/3.jpg" alt="4">
        <img src="img/4.jpg" alt="5">
        <img src="img/4.jpg" alt="6">
    </div>
    <div class="container">
        <span class="on"></span>
        <span></span>
        <span></span>
        <span></span>
    </div>
</div>
<script type="text/javascript">
    window.onload=function(){

        var prev =document.getElementsByClassName("prev");
        var next =document.getElementsByClassName("next");
        var wrap =document.getElementsByClassName("wrap");
        console.log( );
        next.onclick=function(){
            wrap.style.left= parseInt(wrap.style.left)-600+"px";

        }
        prev.onclick=function(){
              wrap.style.left= parseInt(wrap.style.left)+600+"px";
        }
    }

</script>

展开
收起
杨冬芳 2016-06-21 13:36:10 2811 0
1 条回答
写回答
取消 提交回答
  • 码农|Coder| Pythonista

    你把document.getElementsByClassName改成document.getElementById试试。
    或者改成

    var prev =document.getElementsByClassName("prev")[0];
    var next =document.getElementsByClassName("next")[0];
    var wrap =document.getElementsByClassName("wrap")[0];
    2019-07-17 19:44:46
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
Transforming the data center 立即下载
低代码开发师(初级)实战教程 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载