1 <style>
 2     *{
 3         margin: 0;padding: 0;
 4         list-style: none;
 5     }
 6     body{
 7         background: black;        
 8     }
 9     .outer{
10         margin: 10px auto;
11         border: 1px solid white;
12         border-radius: 6px;
13         background-color: white;
14         width: 200px;
15         padding: 8px 6px 6px 8px;
16     }
17     .outer>ul{
18         overflow: hidden;
19     }
20 
21     .outer>ul>li, .outer>ul>li>img{
22         /* 两个部分设置内容一样,选择器写在一起。 */
23         float: left;
24         width: 48px;
25         height: 48px;
26         /* li的宽高不能直接由内部img撑起? */
27 
28         margin: 0 2px 2px 0;
29     }
30     /* .outer>ul>li>img{
31         width: 48px;
32         height: 48px;
33     } */
34     .outer>ul>li:nth-child(1){
35         position:relative;
36         /* 相对定位,子绝父相,给后面的loading动态图div使用。 */
37     }
38     .outer>ul>li:nth-child(1), .outer>ul>li:nth-child(1)>img{
39         /* 两个部分设置内容一样,选择器写在一起。 */
40         width: 148px;
41         height: 148px;
42     }
43 
44     .outer>li.first div{
45     position:absolute;top:0;left:0;
46     width:156px;height:156px;
47     display:none;
48     opacity:0.5;filter:alpha(opacity=50);
49     background:#fff url(img/loading.gif) 50% 50% no-repeat;
50     /* 给第一个大图li加一个空div,添加loading的背景图。 让图片加载时,显示加载动图 */
51     }
52     </style>
53 
54     <script>
55     window.onload = function()
56     {
57         // var aImg = document.getElementsByTagName('img');
58 
59         // for(let i=0; i<aImg.length; i++)
60         // {
61         //     aImg[i].onmouseover = function()
62         //     {
63         //         aImg[0].src = this.src;
64         //     };
65         // };
66 
67         var oImg = document.getElementById("box").getElementsByTagName("img");
68 
69         var oDiv = document.getElementsByTagName("div")[0];
70         // 给第一个大图li加一个空div,添加loading的背景图。 让图片加载时,显示加载动图。
71         for (var i = 1; i < oImg.length; i++)
72         {
73             oImg[i].onmouseover = function ()
74             {                        
75                 var img = new Image();
76 
77                 img.src = oImg[0].src = this.src.replace(/small/,"big");
78                 // replace(); 方法,用于在字符串中用一些字符替换另一些字符。
79                 // 例如:
80                 // var str="Visit Microsoft!"
81                 // document.write(str.replace(/Microsoft/, "W3School"))
82                 // 输出:Visit W3School!
83 
84                 oDiv.style.display = "block";
85 
86                 img.complete ? oDiv.style.display = "none" : (oImg[0].onload = function() {oDiv.style.display = "none"})
87                 // complete  通过Image对象的complete 属性来检测图像是否加载完成。
88                 // onload    当图像装载完毕时调用的事件句柄。
89 
90                 // 所以上面这个三元表达式的意思是:
91                 // img这个图片对象是否加载完成?  
92                 // 加载完成就让div的display为none。   没有加载完成,就调用img的onload事件,让它加载完成,然后运行function 让div的display为none。
93                 
94                 // js Image()对象onload和预加载
95                 // https://segmentfault.com/a/1190000011020722?utm_source=tag-newest
96             }    
97         }
98     };
99     </script>