美文网首页
JavaScript 图片库改进版

JavaScript 图片库改进版

作者: HeroMeikong | 来源:发表于2017-09-08 17:59 被阅读0次

实现图片图的结构、样式和行为彻底分离!!!
gallery.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8"/>
    <title>Image Gallery</title>
    <link rel="stylesheet" type="text/css" href="styles/layout.css" media="screen"/>
</head>
<body>
    <h1>Snapshots</h1>
    <ul id="imagegallery">
        <li>
            <a href="images/fire.jpg"  title="fire1">
                ![](images/short4.jpg)
            </a>
        </li>
        <li>
            <a href="images/coffee.jpg"  title="fire2">
                ![](images/short3.jpg)
            </a>
        </li>
        <li>
            <a href="images/rose.jpg"  title="fire3">
                ![](images/short1.jpg)
            </a>
        </li>
        <li>
            <a href="images/bigben.jpg"  title="fire4">
                ![](images/short2.jpg)
            </a>
        </li>
    </ul>
    <script type="text/javascript" src="scripts/showPic.js"></script>
</body>
</html>

showPic.js

function addLoadEvent(func) {
    var oldonload = window.onload;
    if(typeof window.onload != 'function'){
        window.onload = func;
    }else {
        window.onload = function () {
            oldonload();
            func();
        }
    }
}
function insertAfter(newElement,targetElement) {
    var parent = targetElement.parentNode;
    if (parent.lastChild == targetElement){
        parent.appendChild(newElement);
    } else {
        parent.insertBefore(newElement,targetElement.nextSibling);
    }
}
function showPic(whichpic){
    if(!document.getElementById("placeholder")) return false;
    var source = whichpic.getAttribute("href");
    var placeholder = document.getElementById("placeholder");
    placeholder.setAttribute("src",source);
    if(!document.getElementById("description")) return false;
    if (whichpic.getAttribute("title")) {
        var text = whichpic.getAttribute("title");
    } else {
        var text ="";
    }
    var description = document.getElementById("description");
    if(description.firstChild.nodeType == 3){
        description.firstChild.nodeValue = text;
    }
    return false;
}
function prepareGallery() {
    if(!document.getElementsByTagName) return false;
    if(!document.getElementById) return false;
    if(!document.getElementById("imagegallery")) return false;
    var gallery = document.getElementById("imagegallery");
    var links = gallery.getElementsByTagName("a");
    for( var i=0;i < links.length;i++){
        links[i].onclick = function () {
            return showPic(this);
        }
        links[i].onkeypress = links[i].onclick;
    }
}
function preparePlaceholder() {
    if (!document.createElement) return false;
    if (!document.createTextNode) return false;
    if (!document.getElementById) return false;
    if (!document.getElementById("imagegallery")) return false;
    var placeholder = document.createElement("img");
    placeholder.setAttribute("id","placeholder");
    placeholder.setAttribute("src","images/placeholder.jpg");
    placeholder.setAttribute("alt","my image gallery");
    var description = document.createElement("p");
    description.setAttribute("id","description");
    var desctext = document.createTextNode("Choose an image.");
    description.appendChild(desctext);
    var gallery = document.getElementById("imagegallery");
    insertAfter(placeholder,gallery);
    insertAfter(description,placeholder);
}
addLoadEvent(preparePlaceholder);
addLoadEvent(prepareGallery);

layout.css

body {
    font-family: "Helvetica","Arial",serif;
    color: #333;
    background-color: #ccc;
    margin: 1em 10%;
}
h1 {
    color: #333;
    background-color: transparent;
}
a {
    color: #c60;
    background-color: transparent;
    font-weight: bold;
    text-decoration: none;
}
ul {
    padding: 0;
}
li {
    float: left;
    padding: 1em;
    list-style: none;
}
#imagegallery {
    list-style: none;
}
#imagegallery li {
    display: inline;
}
#imagegallery li a img {
    border: 0;
}

相关文章

  • JavaScript 图片库改进版

    实现图片图的结构、样式和行为彻底分离!!!gallery.html showPic.js layout.css

  • [笔记5]JavaScript DOM编程艺术_JavaScri

    利用JavaScript来创建图片库将是最佳的选择:把整个图片库的浏览链接集中安排在图片库主页里,只在用户点击了这...

  • [笔记7]JavaScript DOM编程艺术_图片库改进版

    勤于思考是每位有创新精神的网页设计人员都应该具备的特质。 平稳退化 第一个问题,如果JS功能被禁用,会怎么样?把h...

  • 「JavaScript 图片库」案例解析

    JavaScript 图片库 任务:编写一个 JavaScript 函数以显示用户想要查看的图片。 思路:将所有图...

  • JavaScript 图片库

    在创建了一个简单的图片浏览网站(点击图片跳转页面显示)之后,需要考虑:1.当点击某个链接时,我希望能留在这个网页而...

  • javascript图片库

    javascript脚本来制作一个图片库,当网页中大量的图片加载进来的时候势必对网站运行的速度会有影响,看了第二版...

  • 《DOM编程艺术》二、javascript图片库

    title: 《DOM编程艺术》二、javascript图片库date: 2017-06-03 10:00:29t...

  • ES6,ES5,TypeScript区别

    TypeScript 是 JavaScript 的超集。ES2015 是 ES5 的改进版本。 一、概念区分 EC...

  • JavaScript 图片库优化版

    在之前的版本上进行修改和优化。 需要考虑的几点: 1、引入了检测和测试吗?代码能平稳退化吗?2、向后兼容3、分离J...

  • javascript简单的图片库

    为什么使用图片库 在网页中,如果一张网页加载太多的图片,那么这张网页将会显示很慢,而且浪费用户流量,而javasr...

网友评论

      本文标题:JavaScript 图片库改进版

      本文链接:https://www.haomeiwen.com/subject/zsrnjxtx.html