jquery實現圖片切換和js實現圖片切換

来源:http://www.cnblogs.com/zeng91/archive/2016/10/12/5954071.html
-Advertisement-
Play Games

jquery實現圖片切換: javascript實現圖片切換: ...


jquery實現圖片切換:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
 <head>
  <meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
  <title></title>
  <script src="http://libs.baidu.com/jquery/2.0.0/jquery.js"></script>
  <script>
    $(function(){
        var num2=6;//用於設置當前選中ol li的z-index值
        $('ol li').mouseover(function(e){
            $(this).attr('class','current');
            $(this).siblings().attr('class','');
            num2++;
            var num=$(this).index();//存ol li的序列號
            $('ul li').eq(num).css('z-index',num2);
            $('ul li').eq(num).css('left','600px');//修改ul li對應的序列號的樣式,先把它的位置絕對定位到div外面

            //$('ul li').eq(num).css('left','0');這句是靜態css,下一句是動態css
            $('ul li').eq(num).animate({left:'0'},50);//然後把它的位置又重新絕對定位到父元素上面  這樣就實現了一個動畫的效果
        });

    });
  </script>
  <style>
    *{
        padding:0;margin:0;border:0;
    }
    .all{/*div的寬高設置成和五張圖片的寬高一樣*/
        width:600px;
        height:300px;
        margin:100px auto;/*div居中*/
        position:relative;/*相對定位,便於子元素使用絕對定位*/
        overflow:hidden;/*隱藏超出部分的圖片*/
    }
    .all ul{
        position:relative;
        z-index:1;
    }
    .all ul li{
        position:absolute;
        left:0;
        top:0;
    }
    .all ol{
        position:absolute;
        z-index:2;/*顯示在ul上面*/
        right:10px;
        bottom:10px;
    }
    .all ol li{
        width:20px;
        height:20px;
        background:#333;
        border:1px solid #ccc;
        font-weight:bold;
        text-align:center;/*左右居中*/
        line-height:20px;/*文本上下居中*/
        float:left;
        list-style:none;
        margin-left:10px;
        color:#ccc;
        margin-top:10px;/*讓放大的li和沒有放大的li下邊框對其*/
    }
    .all ol .current{
        width:30px;
        height:30px;
        line-height:30px;
        border:1px solid #f60;
        color:#f60;
        margin-top:0;/*讓放大的li和沒有放大的li下邊框對其*/
        cursor:pointer;/*增強用戶體驗 變小手*/
    }
  </style>
 </head>

 <body>
  <div class="all">
    <ul>
        <li><img src="01.jpg" width="600" height="300"/></li>
        <li><img src="02.jpg" width="600" height="300"/></li>
        <li><img src="03.jpg" width="600" height="300"/></li>
        <li><img src="04.jpg" width="600" height="300"/></li>
        <li><img src="05.jpg" width="600" height="300"/></li>
    </ul>
    <ol>
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li class="current">5</li>
    </ol>
  </div>
 </body>
</html>

 

 

 

javascript實現圖片切換:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
 <head>
  <meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
  <title></title>
  <style>
    *{
        margin:0;
        padding:0;
    }
    .all{
        width:600px;
        height:350px;
        position:relative;
        overflow:hidden;
        margin:100px auto;
    }
    .all ul{
        z-index:1;
        position:relative;
    }
    .all ul li{
        position:absolute;
        top:0;
        left:0;
    }
    .all ol{
        position:absolute;
        right:10px;
        bottom:10px;
        z-index:2;
    }
    .all ol li{
        width:20px;
        height:20px;
        border:1px solid #fff;
        background-color:#333;
        float:left;
        overflow:hidden;
        margin-right:10px;
        text-align:center;
        line-height:20px;
        color:#fff;
        margin-top:10px;
        font-weight:bold;
    }
    .all ol .current{
        width:30px;
        height:30px;
        border:1px solid #f60;
        color:#f60;
        line-height:30px;
        margin-top:0;
        cursor:pointer;
    }
  </style>
  
  <script>
    //通過id值獲得元素的函數
    function $(id){
        return document.getElementById(id);
    }
    
    //初始化函數
    function initial(){
        olLi=document.getElementsByTagName('ol')[0].getElementsByTagName('li');//獲取ol下的li
        ol=$('tab');//獲取ol元素
        theImg=$('theImg');
        //五張圖片的地址
        addressPic=['01.jpg','02.jpg','03.jpg','04.jpg','05.jpg'];
        
        //遍歷ol下的li
        for(var i=0;i<olLi.length;i++){
            //依次給每個li綁定mouseover事件,該事件執行切換圖片的函數
            olLi[i].addEventListener('mouseover',changePicture,false);
            olLi[i].index=i;//設置ol li的index序列號            
        }
    }
    

    
    //切換圖片
    function changePicture(e){
        e.target.className="current";//將選中的ol下的li的class屬性設置為current,e.target代表選中的li
        
        //清除ol里的空白節點
        cleanWhitespace(ol);
        
        //刪除除當前選中的li外其他li的class屬性值
        nextNode=e.target.nextSibling;//當前節點的下一個節點
        lastNode=e.target.previousSibling;//當前節點的前一個節點
        while(nextNode){//將當前節點後所有的兄弟節點的class屬性清除
            nextNode.setAttribute('class','');
            nextNode=nextNode.nextSibling;
        }
        while(lastNode){//將當前節點前面所有的兄弟節點的class屬性清除
            lastNode.className='';
            lastNode=lastNode.previousSibling;
        }
        
        //實現切換圖片的功能    
        theImg.src=addressPic[this.index];
    }
    
    
    //清除ol下的空白節點
    function cleanWhitespace(oElement)
    {
        for(var i=0;i<oElement.childNodes.length;i++){
            var node=oElement.childNodes[i];
            if(node.nodeType==3 && !/\S/.test(node.nodeValue)){    
                 node.parentNode.removeChild(node)
            }
    }
}

    //給窗體綁定load事件,執行初始化函數initial()
    window.addEventListener('load',initial,false);
  </script>
 </head>

 <body>
  <div class="all">
    <ul>
        <li><img id="theImg" src="01.jpg" width="600px" height="350px"/></li>
    </ul>
    <ol id="tab">
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li class="current">5</li>
    </ol>
  </div>
 </body>
</html>

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • HP-Socket 是一套通用的高性能 TCP/UDP/HTTP 通信框架,包含服務端組件、客戶端組件和 Agent 組件,廣泛適用於各種不同應用場景的 TCP/UDP/HTTP 通信系統,提供 C/C++、C#、Delphi、E(易語言)、Java、Python 等編程語言介面。HP-Socket... ...
  • 一、簡單工廠模式 簡單工廠模式,提供了一種創建對象的便捷方法。創建者通過不同的類型參數,創建相對應的對象。 實現代碼如下: 優點: 在創建固定類型的對象時,比較簡單好用。 缺點: 1. 在添加對象類型時,需要更改Creator類裡面的函數,違反了軟體設計中的開閉原則。 2. Creator類依賴於具 ...
  • Atitit. Atiposter 發帖機 新特性 poster new feature v7 q39 V8 重構iocutilV4,use def iocFact...jettyUtil V8 gui 獨立的gui..使用jetty.. V1 初步實現sina csdn cnblogs V2 實現 ...
  • 在DOM事件深入淺出(一)中,我主要給大家講解了不同DOM級別下的事件處理程式,同時介紹了事件冒泡和捕獲的觸發原理和方法。本文將繼續介紹DOM事件中的知識點,主要側重於DOM事件中Event對象的屬性和方法。 那麼什麼是DOM事件中Event對象呢?事件對象(event object)指的是與特定事 ...
  • 本人是軟體開發的初學者,總結了一點點日常所學,記錄在此,主要目的是鼓勵自己堅持學習,怕有一天忘記了,還能複習曾經學過的知識點。 如有大神路過為我指點迷津,糾正改錯更是感激不盡,但請不要噴我這個菜鳥!謝謝 jQuery Mobile的基本使用方法和簡單的知識點 安裝: <link rel="style ...
  • 網上有很多這方面的教程,但不是苦澀難懂就是從哪copy過來的,反正很長一段時間我是沒看懂,時間長了也沒打算去研究了,主要原因是,基本上很少會遇到那些問題(所以說啊,要是沒有研究精神的才懶得管它)。但自從開始研究CSS以後就一發不可收拾,所以打算把CSS一系列的東西都給研究一遍,當然能研究懂自然是好的 ...
  • js中的不同的數據類型之間的比較轉換規則如下: 1. 對象和布爾值比較 對象和布爾值進行比較時,對象先轉換為字元串,然後再轉換為數字,布爾值直接轉換為數字 2. 對象和字元串比較 對象和字元串進行比較時,對象轉換為字元串,然後兩者進行比較。 3. 對象和數字比較 對象和數字進行比較時,對象先轉換為字 ...
  • 為什麼計算寬度計算網頁像素寬度是為了CSS網頁佈局整齊與相容。常見的我們佈局左右結構網頁或使用padding、margin佈局的時候將計算整頁寬度,如果不計算無論是寬度過大過小就會出現錯位問題。 怎麼計算CSS寬度例一:我們計算一個左右結構的佈局樣式。假如總寬度為400px,那麼左右加起來就應當小於 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...