### 无缝滚动
- 效果演示
- 物体运动基础
- 让 `div` 移动起来
- `offsetLeft/offsetTop` 的作用:获取当前对象的左边距/上边距
- `offsetWidth/offsetHeight`
- 用定时器让物体连续移动:
- `innerHTML` 拼接两节图片, 宽度后面加 `px` 才会生效
- `overflow:hidden;` 隐藏元素外的内容
- 改变滚动的方向
- 修改 `speed`
- 修改判定条件
- 多次点击越来越快:`if (!timer) `或`clearInterval(timer);` 避免重复调用
- 鼠标移入暂停
- 移入关闭定时器
- 移出重新开启定时器
- 代码:
```HTML
<!DOCTYPE html>
<html>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<link rel="stylesheet" href="../reset.css">
<title>移出延时隐藏</title>
<style>
body {
width: 560px;
margin: 0 auto;
}
#d2 {
margin: 10px;
width: 200px;
height: 200px;
background-color: rgb(0, 204, 255);
display: none;
float: left;
}
#d1 {
margin: 10px;
width: 100px;
height: 100px;
background-color: rgb(0, 255, 149);
float: left;
}
#d3 {
margin: 220px auto;
width: 560px;
height: 140px;
position: absolute;
background-color: rgb(135, 182, 182);
overflow: hidden;
}
#u1 {
position: relative;
}
#u1 li {
float: left;
}
</style>
<script>
window.onload = function () {
// 封装 getElementById 函数
function get(id) {
return document.getElementById(id);
}
// 封装 getElementsByTagName
function gets(tagName) {
return document.getElementsByTagName(tagName)
}
// 鼠标移动到 d1 上,d2 显示,移出隐藏;
// 鼠标移到 d2 上,清除定时器,移出 d2 开启定时器
let timer = '';
get('d1').onmouseover= get('d2').onmouseover = function () {
clearTimeout(timer);
get('d2').style.display = 'block';
}
get('d1').onmouseout= get('d2').onmouseout = function () {
timer = setTimeout(hide,1000);
}
function hide() {
get('d2').style.display = 'none';
}
// 无缝滚动
get('u1').innerHTML += get('u1').innerHTML;
get('u1').style.width = gets('li').length * gets('li')[0].offsetWidth + 'px';
let timer2 = '';
let speed = 2;
// 左移
get('btn1').onclick = function () {
speed = -2;
if (!timer2) {
timer2 = setInterval(move, 30);
}
}
// 右移
get('btn2').onclick = function () {
speed = 2;
if (!timer2) {
timer2 = setInterval(move, 30);
}
}
// 移动
function move() {
get('u1').style.left = get('u1').offsetLeft + speed + 'px';
if (get('u1').offsetLeft < -get('u1').offsetWidth/2) {
get('u1').style.left = 0;
} else if (get('u1').offsetLeft > 0){
get('u1').style.left = -get('u1').offsetWidth/2 + 'px';
}
console.log(get('u1').offsetLeft);
}
// 鼠标悬停
get('d3').onmouseover = function () {
clearInterval(timer2);
}
get('d3').onmouseout = function () {
timer2 = setInterval(move, 30);
}
}
</script>
<body>
<div id="d1"></div>
<div id="d2"></div>
<div id="d3">
<ul id="u1">
<li><img src="images/1.png" alt=""></li>
<li><img src="images/2.png" alt=""></li>
<li><img src="images/3.png" alt=""></li>
<li><img src="images/4.png" alt=""></li>
</ul>
</div>
<input type="button" name="" id="btn1" value="左移">
<input type="button" name="" id="btn2" value="右移">
</body>
</html>
```
- 前言
- 初探 JavaScript 魅力
- JavsScript 是什么
- 第一个 JS 特效:鼠标提示框
- 网页换肤和 if 判断
- 函数传参
- 循环 while 和 for
- 导航栏选项卡
- JS 简易日历
- JavaScript 基础
- JavaScript 组成
- 变量类型
- 变量类型转换
- 变量的作用域和闭包
- 命名规范
- 运算符
- 程序流程控制
- JSON
- 深入 JavaScript
- 函数返回值
- 函数传参与行间样式
- 数组基础操作
- 定时器的使用
- 定时器的作用
- 数码时钟
- Date 对象其它方法
- 延时提示框
- 无缝滚动
- DOM基础应用
- DOM 基础
- DOM 节点
- 操作元素属性
- DOM 元素灵活查找
- DOM 操作应用
- 创建、插入和删除元素
- 文档碎片
- DOM操作应用高级
- 表格标签
- 表格应用
- 表单应用
- JS 运动基础
- 运动基础
- 运动框架及应用
- 缓冲运动
- 运动的停止条件
- JS 运动应用
- 多物体运动框架
- 任意值运动框架
- 仿 Flash 图片展示
- JS 运动中级
- 链式运动框架
- 完美运动框架
- 运动框架总结
- 运动框架应用
- JS事件基础
- Event 对象和事件
- 鼠标事件
- 键盘事件
- JS 事件中级
- 默认事件
- 拖拽
- JS 事件高级应用
- 事件绑定
- 高级拖拽
- 自定义滚动条
- Ajax 基础
- Ajax 是什么
- 使用 Ajax
- Ajax 原理
- Ajax 中级
- 编写 Ajax
- Ajax 数据
- JS 面对对象基础
- 面对对象是什么
- JS 中的面对对象
- 第一个面对对象的程序
- 工厂方式
- 原型:Prototype
- 面对对象编程方式
- JS 面对对象实例
- 面对对象的选项卡
- JS 面对对象高级
- Json 方式的面向对象
- 拖拽和继承
- 使用继承
- 系统对象
- BOM 应用
- BOM 基础
- 尺寸及坐标
- 常用方法和事件
- COOKIE 基础与应用
- 什么是 cookie
- 使用 cookie
- JS 中的正则表达式
- 正则表达式基础
- 字符串与正则配合
- 字符串
- 量词
- 常用正则例子
- JS Template 模板引擎
- 特性
- 语法
- 实例
- 表达式和运算符分类
- 主要表达式
- 左表达式
- 自增和自减
- 一元运算符
- 算术运算符
- 关系运算符
- 相等运算符
- 位移运算符
- 二进制位运算符
- 二元逻辑运算符
- 条件(三元)运算符
- 赋值运算符