整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          html+css3+js 創意設計-滑動登錄頁面

          HTML+CSS3+JS創意設計——打造炫酷滑動登錄頁面

          **引言:探索交互之美**

          在Web開發的世界里,優秀的用戶體驗往往始于一個精心設計的登錄界面。HTML5、CSS3以及JavaScript的結合讓我們能夠創造出極具創意與個性化的滑動登錄頁面,讓用戶在首次接觸應用時就能留下深刻印象。本篇文章將詳細介紹如何利用基礎的HTML+CSS3+JS技術,從零開始打造一款令人眼前一亮的滑動登錄頁面,并通過詳細的代碼實例解析,帶領您領略前端交互設計的魅力。

          ---

          ### **一、搭建基礎HTML結構**

          **標題:** 構建骨骼——登錄表單的基礎布局

          首先,我們需要構建一個簡潔明了的HTML結構,包括用戶名輸入框、密碼輸入框、登錄按鈕以及可選的注冊鏈接。為了實現滑動效果,我們還將引入一個容器元素來包裹整個登錄區域。

          ```html

          <!DOCTYPE html>

          <html lang="zh">

          <head>

          <meta charset="UTF-8">

          <title>滑動登錄頁面</title>

          <!-- 引入外部CSS和JS文件 -->

          <link rel="stylesheet" href="styles.css">

          <script src="scripts.js" defer></script>

          </head>

          <body>

          <div id="login-slider">

          <form action="#" class="login-form">

          <input type="text" placeholder="用戶名" required>

          <input type="password" placeholder="密碼" required>

          <button type="submit">登錄</button>

          <a href="#">忘記密碼?</a>

          <a href="#">立即注冊</a>

          </form>

          </div>

          </body>

          </html>

          ```

          ---

          ### **二、CSS3魔法——樣式與動畫**

          **標題:** 點綴肌膚——賦予登錄表單靈動之感

          接下來,我們將使用CSS3為登錄表單添加樣式,并利用`@keyframes`規則定義滑動動畫效果。同時,我們還需要保證登錄表單在不同設備上具有良好的響應式布局。

          ```css

          /* styles.css */

          body {

          margin: 0;

          background-color: #f0f0f0;

          }

          #login-slider {

          position: absolute;

          top: 50%;

          left: 50%;

          transform: translate(-50%, -50%);

          width: 300px;

          height: auto;

          background-color: white;

          box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);

          overflow: hidden;

          }

          .login-form {

          display: flex;

          flex-direction: column;

          padding: 20px;

          animation: slideIn 1s ease-in-out forwards;

          }

          /* 定義滑動動畫 */

          @keyframes slideIn {

          0% {

          transform: translateY(100%);

          }

          100% {

          transform: translateY(0);

          }

          }

          /* 登錄表單元素樣式 */

          input[type="text"],

          input[type="password"] {

          margin-bottom: 10px;

          padding: 10px;

          border: none;

          border-radius: 5px;

          }

          button {

          cursor: pointer;

          background-color: #007bff;

          color: white;

          padding: 10px 20px;

          border: none;

          border-radius: 5px;

          text-transform: uppercase;

          font-weight: bold;

          }

          /* 響應式布局 */

          @media screen and (max-width: 768px) {

          #login-slider {

          width: 90%;

          }

          }

          ```

          ---

          ### **三、JavaScript增強交互**

          **標題:** 賦予靈魂——用JavaScript實現滑動觸發與驗證邏輯

          現在我們要借助JavaScript來控制登錄表單的滑動行為,例如當用戶點擊某個鏈接或者頁面加載完成后自動觸發滑動動畫。同時,可以增加一些簡單的表單驗證功能。

          ```javascript

          // scripts.js

          document.addEventListener('DOMContentLoaded', () => {

          // 頁面加載完成后執行滑動動畫

          const loginSlider = document.getElementById('login-slider');

          loginSlider.classList.add('slide-active');

          // 表單提交事件處理,此處僅為示例,實際場景下需加入真實驗證邏輯

          const form = document.querySelector('.login-form');

          form.addEventListener('submit', (event) => {

          event.preventDefault(); // 阻止默認提交行為

          const username = form.querySelector('input[type="text"]').value;

          const password = form.querySelector('input[type="password"]').value;

          // 實現簡單驗證邏輯,如為空檢查

          if (!username || !password) {

          alert('用戶名和密碼不能為空!');

          } else {

          // 這里可以替換為真實的登錄請求邏輯

          console.log('正在登錄...', username, password);

          }

          });

          });

          ```

          ---

          ### **四、創意無限——拓展與優化**

          **標題:** 持續創新——更多滑動登錄頁面的設計思路與實踐

          除了上述基本的滑動登錄形式,還可以進一步豐富設計,比如:

          - 添加進度條指示登錄滑動完成度;

          - 使用CSS變量實現自定義主題切換;

          - 結合SVG圖標增加視覺吸引力;

          - 通過IntersectionObserver API實現視口可見時自動滑動;

          - 配合AJAX技術實現實時驗證和無刷新登錄。

          ---

          **結語:**

          通過這次對HTML+CSS3+JS組合技術的探索,我們不僅成功地制作出了一個富有創意的滑動登錄頁面,還展現了前端技術在交互設計中的無限可能性。學習并靈活運用這些基礎知識,可以讓您的Web應用更加生動有趣,從而更好地吸引和留住用戶。持續關注前端技術的最新發展,不斷挑戰自我,用代碼書寫更美好的Web世界。

          言:在WEB2.0時代,網速還很慢的時候,最煩惱的就是注冊登錄的時候,如果有其中一個輸入錯誤,提交之后驗證不通過,那就要重新填寫從新提交。在逛論壇的時候,總是要先刷新頁面才能看到新的東西,很不方便,不過現在我們無疑是幸福的,因為有了ajax技術,我們不在百無聊賴的刷新刷新刷新,本文章就來簡單講解一下如何使用javascript原生語言編寫一個完整ajax的使用方法。

          聲明:本文章只針對有興趣或者即將有興趣學習相關知識的同學,文章很基礎,大神請自便,文章若有錯誤,請大家指正。

          名詞解釋:ajax(Asynchronous Javascript And XML)

          ajax,也就是異步javascript和xml,是一種用來創建快速動態網頁的技術。在我個人看來,這其實不算是一種技術,準確的說,應該是一種方法,一種提升用戶體驗的方法。ajax通過在后臺與服務器進行少量數據交換,AJAX 可以使網頁實現異步更新。這意味著可以在不重新加載整個網頁的情況下,對網頁的某部分進行更新。通俗的講,ajax的作用就是,當你正在瀏覽或者使用網頁的時候,你的網頁并不是如你所見一層不變的,而是它在后面對服務器請求需要的數據,并且把它顯示在網頁里。在整個過程,你是看不到它在跟服務器交流。平時最常見的就是我們的注冊登錄頁面,登錄的時候,點擊登錄,頁面明明沒有跳轉,但是卻能提示你用戶名和密碼錯誤,注冊的時候,我們才剛輸入用戶名,它就提示你該用戶名已經存在,這是為什么?其實就是ajax的功勞,它在你繼續使用的網頁的時候,已經悄悄的跟服務器聯系上了,并且驗證了你的信息,還返回提醒了你。整個過程我們就稱是異步請求的過程。這就是ajax最經典的應用。下面我們看看怎么使用JavaScript創建一個ajax吧。

          創建一個ajax主要分為幾個步驟:

          1、創建XMLHttpRequest 對象

          2、向服務器發送請求

          3、服務器接收ajax的請求,接收傳過來的數據,處理后返回數據

          4、客戶端接收數據,完成局部更新網頁

          創建XMLHttpRequest對象的語法:

          variable=new XMLHttpRequest();

          如需將請求發送到服務器,我們使用 XMLHttpRequest 對象的 open() 和 send() 方法

          xmlhttp.open("GET","test1.txt",true); //打開一個跟服務器的連接

          xmlhttp.send('data'); //發送數據

          這時候已經跟服務器取得聯系,接下來就是等待服務器返回數據了,那我們要怎么知道服務器什么時候返回呢,這時候就用到readyState這個屬性了,這個屬性的值保存了XMLHttpRequest 的狀態。

          • 0: 請求未初始化

          • 1: 服務器連接已建立

          • 2: 請求已接收

          • 3: 請求處理中

          • 4: 請求已完成,且響應已就緒

          如果readyState==4的時候就代表已經完成所有請求了,這時候寫一個回調函數取數據就好了。

          取數據語法:

          var data=XMLHttpRequest.responseText

          這樣基本上就完成了一個簡單的ajax請求。

          注意:以上只是大概介紹了ajax的使用方法,如果真的用到了,還需要去仔細閱讀詳細文檔。因為ajax是與服務器打交道的,所以你至少了解服務器的一些相關知識,比如PHP,Java之類的語言。其實使用原生寫ajax麻煩,不方便,早就有人幫我們封裝好了,比如jquery,mui等等封裝的都比較好用,希望大家明白原生道理后多去了解了解別人的框架。

          此頭條號不定期分享一些常用的開發方法,與同學們共同學習,共同進步,歡迎大家訂閱!!!更多詳細,請關注www.ittas.cn網站。

          件拖拽上傳

          使用HTML5的文件API, 可以將操作系統中的文件拖放到瀏覽器的指定區域, 實現文件上傳到服務器。本文將結合實例講解HTML5+jQuery+PHP實現拖拽上傳圖片的過程, 來看下HTML5的魅力吧。

          HTML

          我們在頁面中放置一個拖拽區域#drop_area, 即接收拖拽的區域, #preview用來預覽拖拽上傳的圖片信息。

          <div id="drop_area">將圖片拖拽到此區域</div>
          <div id="preview"></div>

          Javascript

          要想實現拖拽, 頁面需要阻止瀏覽器默認行為, 即四個事件(拖離、拖后放、拖進、拖來拖去), 因為我們要阻止瀏覽器默認將圖片打開的行為, 這里我們使用jQuery來完成。

          $(function(){
          //阻止瀏覽器默認行。
          $(document).on({
              dragleave:function(e){ //拖離
              e.preventDefault();
          },
          drop:function(e){ //拖后放
              e.preventDefault();
          },
          dragenter:function(e){ //拖進
              e.preventDefault();
          },
          dragover:function(e){ //拖來拖去
              e.preventDefault();
          }
          });
          ...
          });

          接下來我們來了解下文件API。HTML5的文件API有一個FileList接口, 它可以通過e.dataTransfer.files拖拽事件傳遞的文件信息, 獲取本地文件列表信息

          var fileList = e.dataTransfer.files;

          在本例中, 我們用javascript來偵聽drop事件, 首先要判斷拖入的文件是否符合要求, 包括圖片類型、大小等, 然后獲取本地圖片信息, 實現預覽, 最后上傳。

          $(function(){
          /// ...接上部分
          var box = document.getElementById('drop_area'); //拖拽區域
          box.addEventListener("drop",function(e){
          e.preventDefault(); //取消默認瀏覽器拖拽效果
          var fileList = e.dataTransfer.files; //獲取文件對象
          //檢測是否是拖拽文件到頁面的操作
          if(fileList.length == 0){
              return false;
          }
          //檢測文件是不是圖片
          if(fileList[0].type.indexOf('image') === -1){
          alert("您拖的不是圖片!");
          return false;
          }
          
          //拖拉圖片到瀏覽器,可以實現預覽功能
          var img = window.URL.createObjectURL(fileList[0]);
          var filename = fileList[0].name; //圖片名稱
          var filesize = Math.floor((fileList[0].size)/1024);
          if(filesize>500){
          alert("上傳大小不能超過500K.");
          return false;
          }
          var str = "<img src='"+img+"'><p>圖片名稱:"+filename+"</p><p>大小:"+filesize+"KB</p>";
          $("#preview").html(str);
          
          //上傳
          xhr = new XMLHttpRequest();
          xhr.open("post", "upload.php", true);
          xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest");
          
          var fd = new FormData();
          fd.append('mypic', fileList[0]);
          
          xhr.send(fd);
          },false);
          });

          我們用FormData模擬表單數據, 直接將數據append到formdata對象中, 實現了ajax上傳。

          PHP

          upload.php用于接收上傳的文件信息, 完成上傳, 實現代碼如下:

          <?php
          $mypic = $_FILES["mypic"];
          if(!empty($mypic)){
          $picname = $_FILES['mypic']['name'];
          $picsize = $_FILES['mypic']['size'];
          if ($picsize > 512000) {
          echo '圖片大小不能超過500k';
          exit;
          }
          $type = strstr($picname, '.');
          if ($type != ".gif" && $type != ".jpg") {
          echo '圖片格式不對!';
          exit;
          }
          $pics = 'helloweba' . $type;
          //上傳路徑
          $pic_path = "pics/". $pics;
          move_uploaded_file($mypic["tmp_name"],$pic_path);
          }
          ?>

          下邊這幾句可以沒有

          <meta charset="utf-8">
          <form action="" method="post" enctype="multipart/form-data">
          <input type="file" name="mypic">
          <input type="submit" value="上傳">
          </form>

          最后總結下HTML5實現拖拽上傳的技術要點:

          1、監聽拖拽:監聽頁面元素的拖拽事件, 包括:dragenter、dragover、dragleave和drop, 一定要將dragover的默認事件取消掉, 不然無法觸發drop事件。如需拖拽頁面里的元素, 需要給其添加屬性draggable=”true”;

          2、獲取拖拽文件:在drop事件觸發后通過e.dataTransfer.files獲取拖拽文件列表, .length屬性獲取文件數量, .type屬性獲取文件類型。

          3、讀取圖片數據并添加預覽圖。

          4、發送圖片數據:使用FormData模擬表單數據AJAX提交文件流。


          主站蜘蛛池模板: 日韩国产一区二区| 精品一区二区三区无码视频| 精品国产日韩亚洲一区在线| 中文字幕在线一区| 亚洲国产成人一区二区精品区| 美女一区二区三区| 91在线一区二区| 国产亚洲福利精品一区| 美女免费视频一区二区三区| 日韩在线一区二区| 国产一区二区精品尤物| 亚洲av无码天堂一区二区三区 | 伊人久久大香线蕉av一区| 亚洲午夜在线一区| 波多野结衣高清一区二区三区| 国产成人av一区二区三区不卡| 亚洲视频在线一区二区三区| 亚洲日韩精品一区二区三区| 精品无码国产一区二区三区51安| 精品少妇人妻AV一区二区三区| 亚洲成在人天堂一区二区| 亚洲无人区一区二区三区| 欧洲精品码一区二区三区免费看| 欧洲亚洲综合一区二区三区| 一区二区三区在线免费观看视频| 韩国精品一区二区三区无码视频| 亚洲欧美成人一区二区三区 | 亚洲一区视频在线播放| 高清一区二区三区视频| 久久影院亚洲一区| 美女视频一区三区网站在线观看| 一区二区乱子伦在线播放| 亚洲一本一道一区二区三区| 一区二区三区日本视频| 久久亚洲日韩精品一区二区三区| 任你躁国语自产一区在| 一区二区三区内射美女毛片| 亚洲国产成人精品无码一区二区| 国产精品亚洲一区二区无码 | 美女AV一区二区三区| 中文字幕精品无码一区二区|