慕娘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);
};
楼上正解
再有就是老师在最开始写html代码插入模板图片的时候,把第一张图片1.jpg复制了一个,并且把复制的图片的名字改成了{{index}}.jpg然后直接传入成了模板图片
需要用两个花括号把<img class="picture" src="image/index.jpg" />中的 index 括起来,形成模板字符串,以便将图片传入。如下所示应该写成<img class="picture" src="image/{{index}}.jpg" />再有就是,只要是属于模板的字符串 index 和 h2 和 h3 都要用两个花括号括起来,无论是html里面的还是js里面的,你应该可以在视频中看到老师都括起来了的,而且也有大概讲到{{}}的用法
JS+CSS3实现带预览图幻灯片效果
53759 学习 · 265 问题
相似问题