如果不使用 javascript,我不相信有任何方法可以解决这个问题。浏览器相对于该页面的左上角呈现页面,因此位于该 0,0 点上方或左侧的任何内容实际上都在屏幕外。所有溢出都发生在底部和右侧。这与任何块元素内部的内容相同。因此,如果您有一个相对于页面右侧定位的项目,宽度超过 100%。0,0 原点左侧的部分将简单地在屏幕外。
不过,我希望有人能证明我错了。
这是一个有效的javascript解决方案:
<html>
<head>
<style type="text/css" rel="stylesheet">
    * {margin:0;padding:0;}
    div#box {background-color:green;width:1000px;}
    #box {position:absolute;top:0;left:0;}
    .clearer {clear:both;}
</style>
</head>
<body>
    <div id="box">
        asdafdsf
    </div>
    <div class="clearer"></div>
    <script type="text/javascript">
        function layout() {
            if( typeof( window.innerWidth ) == 'number' )
                this.screenWidth = window.innerWidth;   
            else //patch for IE
                this.screenWidth = document.body.clientWidth;
            this.el = document.getElementById('box')
            if (this.el.offsetWidth > this.screenWidth)
                window.scroll(this.el.offsetWidth,0);
            else
                this.el.style.left = (this.screenWidth - this.el.offsetWidth) + 'px';
        }
        function eventListener(el,action,func) {
            if (el) {
                if (el.addEventListener)
                    el.addEventListener(action, func, false);
                else if (el.attachEvent)
                    el.attachEvent('on' + action, func);
            }
        }
        eventListener(window,'resize',layout);
        layout();        
    </script>
</body>
</html>