<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
    <style type="text/css">
        *{ margin: 0; padding: 0; }
        body{ font-size: 12px; }
        #wrap{ width: 660px; margin: 0 auto;}
        #article{  font-size: 14px; font-family: 'TIMES NEW ROMAN'}
        ul{ list-style: none;}
        #nodeTree{-moz-user-select:none; position: absolute; right: 10px; top:10px; width: 200px; overflow: hidden; margin-left: 100px; padding: 15px 0; border: 3px solid #073749; background: #fff; border-radius: 4px; box-shadow: -5px 5px 10px #000; cursor: move;}
        p{ text-indent: 2em;}
        li{ line-height: 24px; padding: 0 0 0 20px; list-style: none; }
        h3:hover{ background: #e4e4e4; cursor: move;}
    </style>
</head>
<body>
<div id="wrap">
<form action="" style="border: 1px solid #d4d4d4; line-height: 2em;">
    <h2>测试表单</h2>
    <p>有bug欢迎指出,联系<a href="http://www.cnblogs.com/xesam/">小西山子</a></p>
</form>
<div id="article">
<h1>Rush</h1>
<p>Swallows may have gone, but there is a time of return; willow trees may have died back, but thre is a time of regreening; peach blossoms may have died back, but they will bloom again. Now, you the wise, tell me , why should our days leave us, never to return? If they had been stolen by someone, who could it be? Where could he hide them? If they had made the escape themselves, then where could they stay at the moment?</p>
<p>I don't know how many days I have been given to spend, but I do feel my hands are getting empty. Takong stock silently, I find that more han eight thousand days have already slid away from me. Like a drop of water from the point of a needle disappearing into the ocean, my days are dripping into the stream of time, soundless, traceless.</p>
<p>Already sweat is starting on my forehead, and tears is welling up in my eyes.</p>
<p>Those that have gone have gone for good, those to come keep coming; yet in between, how swift is the shift, in such a rush?</p>
<p>When I get up in the morning, the slanting sun marks its presence caught, blankly, in his revolutiong. Thus-the day flows away though the sink when I wash my hands, wears off in the bowl when I eat my meal, and passes away before my day-dreaming gaze as reflect in silence. Icanfeel his haste now, so I reach out my hands to hold him back, but he keeps flowing past my withholding hand. In the evening, as I lie in bed, he strides over my body, glides past my feet, in his agile way. The moment  I open my eyes and meet the sun again, ine whole day has gone.I bury my face in my hands and heave a sigh. but the new day begins to flash past in the sigh.</p>
<p>What can I do, in this bustling world, wiht my days flying in their escape? Nothing but to hesitate, to rush. What have I been doing in that eight-thousand-day rush, apart from hesitating?Those bygone days have been dispersed as smoke by a light wind, or evaporated as mist by the morning sun. What traces have I left behind me ? Have I ever left behind any gossamer traces at all? I have come to the world, stark naked; am I to go back, in a blink, in the same stark nakedness?</p>
<p>It is not fair though: why should I have made sush a trip for nothing?</p>
<p>Youthe wise, tell me, why hsould our days leave us, never to return?</p>
<p>By Zhu Ziqing</p>
</div>
</div>
<script type="text/javascript">
    var Tree = (function(){
        function walkDom(el){
            var c = el.firstChild;
            var retObj = {};
            var array = [];
            while(c !== null){//这里只是返回了元素节点,没有节点就是个空数组
if(c.nodeType == 1){
                    array.push(walkDom(c));
                }
                c = c.nextSibling;
            }
            retObj[el.tagName] = {};
            retObj[el.tagName]['domPointer'] = el;
            retObj[el.tagName]['nodeArray']  = array;
            return retObj;
        }
        function createTree(tree){
            for(var key in tree){
                var h3 = document.createElement('h3');
                    h3.appendChild(document.createTextNode(key.toLowerCase()));
                    h3.domPointer = tree[key].domPointer;
                var li =  document.createElement('li');
                    li.appendChild(h3);
                if(tree[key]['nodeArray'].length != 0){
                    var ul = document.createElement('ul');
                    for(var i = 0; i < tree[key]['nodeArray'].length; i++){
                        ul.appendChild(createTree(tree[key]['nodeArray'][i]));
                    }
                    li.appendChild(ul);
                }
            }
            return li;
        }
        function createNodeList(root,target,id){
            var nodeTree = walkDom(document.body);
            var nodeList = document.createElement('ul');
                nodeList.appendChild(createTree(nodeTree))
                nodeList.id = id || 'nodeTree';
            target.appendChild(nodeList);
        }
        return {
            walkDom : walkDom,
            createTree : createTree,
            createNodeList:createNodeList
        }
    })();
    Tree.createNodeList(document.body,document.body,'nodeTree');
    
    function $(id){
        return document.getElementById(id);
    }
    function getMousePos(e){
        return {
            x : e.pageX || e.clientX + document.body.scrollLeft,
            y : e.pageY || e.clientY + document.body.scrollTop
        }
    }
    function getElementPos(el){
        return {
            x : el.offsetParent ? el.offsetLeft + arguments.callee(el.offsetParent)['x'] : el.offsetLeft,
            y : el.offsetParent