大图无法显示,下面是代码(除了css样式代码没传)

来源:3-4 总结

慕娘5154066

2016-11-24 14:26

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <title>幻灯片</title>
   <style>
       * {
           padding: 0;
           margin: 0;
       }
       body {
           padding: 50px 0;
           background-color: #FFF;
           font-size: 14px;
           font-family: 'Avenir Next'; /*字体类型*/
color: #555;
           -webkit-font-smoothing: antialiased; /* 字体抗锯齿 */
}

   </style>
   <link rel="stylesheet" type="text/css" href="box.css">
</head>
<body>
   <div class="slider">
       <!--模板修改 第0步,修改 VIEW -> Template(关键字替换),添加 template id-->
<div id="template_main" class="main">
           <div id="main_{{index}}" class="main-i css">
               <div class="caption">
                   <h2>h2</h2>
                   <h3>h3</h3>
               </div>
               <img class="picture" src="image/index.jpg" />
           </div>
       </div>
       <div id="template_ctrl" class="ctrl">
           <a class="ctrl-i" id="ctrl_index" href="javascript:switchSlider(index);"><img src="image/index.jpg" /></a>
       </div>
   </div>
   <script src="box.js"></script>

</body>
</html>

下面是链接的 js 代码

/**
* Created by mac on 2016/11/24.
*/

   /******  1. 数据定义,( 实际生产环境中,应由后台给出 )********/
var data = [
   {img:1,h1:'Creative',h2:'DUET'},
   {img:2,h1:'Friendly',h2:'DEVIL'},
   {img:3,h1:'Tranquilent',h2:'COMPATRIOT'},
   {img:4,h1:'Insecure',h2:'HUSSLER'},
   {img:5,h1:'Loving',h2:'REBEL '},
   {img:6,h1:'Passionate',h2:'SEEKER'},
   {img:7,h1:'Crazy',h2:'FRIEND'}
];

/*********   2. 通用函数    *************/
var g = function (id) {
   if (id.substr == '.'){
       return document.getElementsByClassName(id.substr(1));
   }
   return document.getElementById(id);
}

/*********   3. 添加幻灯片的操作 (所有幻灯片 & 对应的按钮 )    *************/
function addSliers() {
   // 3.1  获取模板
   var tpl_main = g('template_main').innerHTML
                   .replace(/^\s*/,'')
                   .replace(/^\s*$/,'');//清楚空格
   var tpl_ctrl = g('template_ctrl').innerHTML
                   .replace(/^\s*/,'')
                   .replace(/^\s*$/,'');
   // 3.2 定义最终输出的 HTML 的变量
   var out_main = [];
   var out_ctrl = [];
   // 3.3 遍历所有数据,构建最终输出的 HTML
   for ( i in data){
                                           //正则表达式,g表示全局替换,把index替换成img
       var _html_main = tpl_main.replace(/index/g,data[i].img)
                               .replace(/h2/g,data[i].h1)
                               .replace(/h3/g,data[i].h2)
                               .replace(/css/g,['','main-i_right'][i%2]);
       var _html_ctrl = tpl_ctrl.replace(/index/g,data[i].img);
       out_main.push(_html_main);
       out_ctrl.push(_html_ctrl);
   }
   // 3.4 吧 HTML 回写到对应的 DOM 里
   g('template_main').innerHTML = out_main.join('');
   g('template_ctrl').innerHTML = out_ctrl.join('');

   // 7.1  增加 #main-background
   g('template_main').innerHTML += tpl_main.replace(/index/g,'{{index}}')
                                           .replace(/h2/g,data[i].h1)
                                           .replace(/h3/g,data[i].h2);
   g('main_index').id = 'main_background';

}
   // 5. 幻灯片切换
function switchSlider(n) {
   // 5.1 获得要展现的幻灯片控制按钮 DOM
   var main = g('main_' + n);
   var ctrl = g('ctrl_' + n);
   // 5.2 获得所有的幻灯片以及控制按钮
   var clear_main = g('.main - i');
   var clear_ctrl = g('.ctrl - i');
   // 5.3  清楚 active 样式
   for (i = 0;i<clear_ctrl.length;i ++){
       clear_main[i].className = clear_main[i].className.replace('main-i_active','');
       clear_ctrl[i].className = clear_ctrl[i].className.replace('ctrl-i_active','');
   }
   // 5.4 为当前 按钮和幻灯片 添加附加样式
   main.className += 'main-i_active';
   ctrl.className += 'ctrl-i_active';

   // 7.2  切换时,复制上一张幻灯片到 main_background 中
   setTimeout(function () {
       g('main_background').innerHTML = main.innerHTML;
   },1000);
}
/*********   6. 动态调整图片的  margin-top 使之垂直居中    *************/
function movePictures() {
   var pictures = g('.picture');
   for (i = 0;i < pictures.length;i ++){
       pictures[i].style.marginTop = (-1 * pictures[i].clientHeight / 2) + 'px';
   }
}
/*********   4.定义幻灯片何时输出    *************/
window.onload = function () {
   addSliers();
   switchSlider(2);
   setTimeout(function () {
       movePictures();
   },1000);
};
























写回答 关注

3回答

  • wumu_zhuangzhu
    2018-11-25 11:51:30

    楼上正解

  • 泽_宇儿
    2016-11-26 14:03:17

    再有就是老师在最开始写html代码插入模板图片的时候,把第一张图片1.jpg复制了一个,并且把复制的图片的名字改成了{{index}}.jpg然后直接传入成了模板图片

  • 泽_宇儿
    2016-11-26 13:57:28

    需要用两个花括号把<img class="picture" src="image/index.jpg" />中的 index 括起来,形成模板字符串,以便将图片传入。如下所示应该写成<img class="picture" src="image/{{index}}.jpg" />再有就是,只要是属于模板的字符串 index 和 h2 和 h3 都要用两个花括号括起来,无论是html里面的还是js里面的,你应该可以在视频中看到老师都括起来了的,而且也有大概讲到{{}}的用法

JS+CSS3实现带预览图幻灯片效果

同样的幻灯片,不一样的切换,学会实现思路,操作很简单

53759 学习 · 265 问题

查看课程

相似问题