惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
H
Hacker News: Front Page
P
Palo Alto Networks Blog
T
ThreatConnect
Apple Machine Learning Research
Apple Machine Learning Research
博客园_首页
T
True Tiger Recordings
P
Privacy & Cybersecurity Law Blog
B
Blog
IT之家
IT之家
Last Week in AI
Last Week in AI
F
Full Disclosure
Hacker News: Ask HN
Hacker News: Ask HN
C
Comments on: Blog
Microsoft Azure Blog
Microsoft Azure Blog
C
Cybersecurity and Infrastructure Security Agency CISA
Microsoft Security Blog
Microsoft Security Blog
博客园 - 【当耐特】
N
News and Events Feed by Topic
NISL@THU
NISL@THU
腾讯CDC
雷峰网
雷峰网
Security Latest
Security Latest
李成银的技术随笔
M
Microsoft Research Blog - Microsoft Research
L
LangChain Blog
L
Lohrmann on Cybersecurity
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
C
Check Point Blog
Y
Y Combinator Blog
Recent Announcements
Recent Announcements
博客园 - Franky
N
News | PayPal Newsroom
V
V2EX
A
About on SuperTechFans
The Register - Security
The Register - Security
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google Online Security Blog
Google Online Security Blog
MyScale Blog
MyScale Blog
Cisco Talos Blog
Cisco Talos Blog
Vercel News
Vercel News
WordPress大学
WordPress大学
C
Cyber Attacks, Cyber Crime and Cyber Security
The Hacker News
The Hacker News
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
爱范儿
爱范儿
A
Arctic Wolf
L
LINUX DO - 最新话题
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More

博客园 - 陈大欠

Step Builder:让对象构建有顺序、有边界、有校验 基于 Attribute 的 AOP 字段校验 浅析 .NET 响应式编程 IObservable与ReactiveX Cron表达式简明教程 正则表达式拾遗 快速批量升级 NugetPackage 版本 C# IEquatable和IEqualityComparer 最佳实践 使用XDT提高开发效率 如何保证XML正确性 分析 Dump 入门简明教程 Git commit emoji 对照表 ELK Stack 笔记 HTML5/CSS3(PrefixFree.js) 3D文字特效 Jquery实现图片上下一张 使用jquery构建Metro style 返回顶部 使用js实现移动设备访问跳转到指定目录 从一幅图中了解开源世界 Jquery ajax 学习笔记 工欲善其事必先利其器系列之:在VS里面折叠js代码
js css 构建滚动边框
陈大欠 · 2014-04-11 · via 博客园 - 陈大欠

注:预览效果请点击result选项卡,个人认为这种效果非常适合做友情链接.

完整代码

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>边框虚线旋转</title>
    <style type="text/css" charset="utf-8">
        .coop-list {
            position: relative;
            width: 60%;
            overflow: hidden;
            margin: 20px;
        }

        .topBorder-move {
            position: relative;
            left: -1500px;
            width: 3000px;
            border-top: 2px dashed #DADDE1;
        }

        .bottomBorder-move {
            position: relative;
            left: -1500px;
            width: 4000px;
            border-bottom: 2px dashed #DADDE1;
        }

        .leftBorder-move {
            position: absolute;
            top: -1500px;
            width: 1px;
            height: 4000px;
            border-left: 2px dashed #DADDE1;
        }

        .rightBorder-move {
            position: absolute;
            right: 0;
            top: -1500px;
            width: 1px;
            height: 3000px;
            border-right: 2px dashed #DADDE1;
        }
    </style>
</head>

<body>
    <div class="coop-list">
        <div class="topBorder-move" id="J_borTop"></div>
        <div class="leftBorder-move" id="J_borLeft"></div>
        <div> 转啊转啊转啊转</div>
        <div class="rightBorder-move" id="J_borRight"></div>
        <div class="bottomBorder-move" id="J_borBottom"></div>
    </div>

    <script>
        var getStyleValue = function (ele, attr) {
            var doc = document;
            var style = ele.currentStyle || doc.defaultView.getComputedStyle(ele, null);
            return parseInt(style[attr].replace(/px/g, ""));
        };

        var $G = function (id) {
            return document.getElementById(id);
        };

        (function () {
            var borTop = $G("J_borTop"),
                 borBottom = $G("J_borBottom"),
                 borLeft = $G("J_borLeft"),
                 borRight = $G("J_borRight"),
                 left = getStyleValue(borTop, 'left'),
                 top = getStyleValue(borLeft, 'top');

            setInterval(function () {
                if (left < 0) {
                    left += 2;
                    borRight.style.top = left + "px";
                    borTop.style.left = left + "px";
                } else {
                    left = -1500
                };

                if (top > -3000) {
                    top -= 2;
                    borBottom.style.left = top + "px";
                    borLeft.style.top = top + "px";
                } else {
                    top = -1500
                };
            }, 60);
        })();
    </script>
</body>
</html>