整合營銷服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          html+css3+js 創(chuàng)意設(shè)計-滑動登錄頁面

          HTML+CSS3+JS創(chuàng)意設(shè)計——打造炫酷滑動登錄頁面

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

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

          ---

          ### **一、搭建基礎(chǔ)HTML結(jié)構(gòu)**

          **標(biāo)題:** 構(gòu)建骨骼——登錄表單的基礎(chǔ)布局

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

          ```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魔法——樣式與動畫**

          **標(biāo)題:** 點綴肌膚——賦予登錄表單靈動之感

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

          ```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;

          }

          /* 響應(yīng)式布局 */

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

          #login-slider {

          width: 90%;

          }

          }

          ```

          ---

          ### **三、JavaScript增強(qiáng)交互**

          **標(biāo)題:** 賦予靈魂——用JavaScript實現(xiàn)滑動觸發(fā)與驗證邏輯

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

          ```javascript

          // scripts.js

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

          // 頁面加載完成后執(zhí)行滑動動畫

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

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

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

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

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

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

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

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

          // 實現(xiàn)簡單驗證邏輯,如為空檢查

          if (!username || !password) {

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

          } else {

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

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

          }

          });

          });

          ```

          ---

          ### **四、創(chuàng)意無限——拓展與優(yōu)化**

          **標(biāo)題:** 持續(xù)創(chuàng)新——更多滑動登錄頁面的設(shè)計思路與實踐

          除了上述基本的滑動登錄形式,還可以進(jìn)一步豐富設(shè)計,比如:

          - 添加進(jìn)度條指示登錄滑動完成度;

          - 使用CSS變量實現(xiàn)自定義主題切換;

          - 結(jié)合SVG圖標(biāo)增加視覺吸引力;

          - 通過IntersectionObserver API實現(xiàn)視口可見時自動滑動;

          - 配合AJAX技術(shù)實現(xiàn)實時驗證和無刷新登錄。

          ---

          **結(jié)語:**

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

          TML頁面功能的使用(Webserver):

          通過SIMATIC HMI 面板集成的HTML頁面功能將HMI設(shè)備組態(tài)為HTTP服務(wù)器,實現(xiàn)PC端與精智面板之間的文件傳遞等功能。

          1. 功能組態(tài)

          需注意:HTML頁面功能僅支持精智面板(Comfort Panel)和二代移動面板(2nd Mobile Panel)。

          在觸摸屏項目"運(yùn)行系統(tǒng)設(shè)置"的“服務(wù)”中激活HTML頁面功能:

          2. 功能設(shè)置

          把要監(jiān)控的數(shù)據(jù)在 觸摸屏變量表里找到屬性勾選優(yōu)良生產(chǎn)規(guī)范;

          下載項目至實際硬件后,在觸摸屏控制面板的“WinCC Internet Settings”中會增加"Web Server"選項; win+c 可以進(jìn)入觸摸屏設(shè)置;

          在"Tag authenticate"組中確定訪問服務(wù)器操作設(shè)備變量的驗證方式,“No authentication”為無需驗證,“Authentication required”為訪問需要密碼。

          在“Tag acces”組中確定訪問服務(wù)器操作設(shè)備變量的方式,“Read/write”為讀取訪問和寫訪問,“Read Only”為讀取訪問。

          點擊“User Administration”按鈕進(jìn)入“UserDatabase-Edit”界面,如下圖所示。自行設(shè)置默認(rèn)用戶“Administrator”的密碼和確認(rèn)密碼,密碼和確認(rèn)密碼必須保持一致。如果需要登錄新的用戶,可以點擊"New"按鈕新建用戶,同時輸入用戶名和密碼后,點擊“Apply”確認(rèn)設(shè)置。


          3. 功能使用

          在PC端使用瀏覽器進(jìn)行訪問,在瀏覽器地址欄中輸入https://觸摸屏的IP地址,例如:https://192.168.101.120。輸入設(shè)置的用戶名和密碼。需注意:用戶名是區(qū)分大小寫的。如果需要瀏覽外部存儲介質(zhì)的文件,例如下載或者上傳文件,點擊“File Browser”就可以看到存儲介質(zhì)。

          定義登錄頁面

          前面無論是使用默認(rèn)配置,還是自定義配置類,都是使用的springboot-security自帶的登錄頁面,自帶的登錄頁面在這個版本雖然設(shè)計的非常不錯,但是在實際開發(fā)中,我們通常還是使用自己的登錄頁面。下面來寫一個非常簡單的登錄頁面:

          這個頁面只有填寫用戶名和密碼的地方,然后就是一個form表單提交,沒有任何其他內(nèi)容。特別注意!!這里頁面雖然引入了thymeleaf模板,但是沒有使用thymeleaf的任何標(biāo)簽屬性,使用的是原生的html標(biāo)簽。繼續(xù)下面,然后是定義登錄頁面的路徑:

          這樣登錄頁面就添加完成了。

          修改配置類

          在配置類中添加自定義登錄頁面很簡單,定義登錄頁面鏈接即可:

          配置完成后,啟動項目,訪問登錄頁面,可以看到這樣一個錯誤:

          顯示重定向次數(shù)過多。原來前面我們授權(quán)配置的時候,所有自定義的路徑在未登錄的情況下,都會重定向到登錄頁面,現(xiàn)在登錄路徑也是自定義的,所以它一直在自我重定向。登錄路徑本身要配置成不需要授權(quán)就能訪問的路徑才合理。配置方式很簡單,只需要加上一個 permitAll 方法即可:

          現(xiàn)在重啟項目,訪問登錄可以正常訪問,輸入賬號也可以正常訪問了!

          csrf配置

          上面的頁面和配置類修改好了以后,輸入賬號登錄,卻發(fā)現(xiàn)登錄一直不成功,總是會跳轉(zhuǎn)到登錄頁面。這是什么原因呢?上面的提到了頁面使用的是原生的html標(biāo)簽,沒有使用thymeleaf模板的屬性。先說這種原生的情況,之所以登錄不成功,原因是Spring Security默認(rèn)是開啟CSRF的,所以需要請求中包含CSRF的token信息,在其官方文檔中,提供了在form中嵌入一個hidden標(biāo)簽來獲取token信息,其原理是,hidden標(biāo)簽使用了Spring Security提供的標(biāo)簽,即${csrf.parameterName}、${csrf.token}, 后臺頁面渲染過程中,將此標(biāo)簽解所對應(yīng)的值解析出來,這樣,我們的form表單,就嵌入了Spring Security的所需的token信息,在后續(xù)的提交登錄請求時,就不會出現(xiàn)沒有CSRF token的異常。做法如下:

          這時候登錄,就發(fā)現(xiàn)可以成功。在springboot2.1.x版本下,還有第二種更好的解決方案,就是使用thymeleaf模板的form標(biāo)簽屬性:

          在form標(biāo)簽中,使用th:action屬性,這樣會在表單中默認(rèn)添加一個hidden的input標(biāo)簽,效果和第一種解決方式類似,查看源碼,就可以看到:

          另外,還有一個解決辦法是,通過關(guān)閉CSRF來解決,這個幾乎在任何場景中都能解決這個問題(上面這個解決方案,可能在某些渲染模板不能解析出來token值,不過可以通過后臺程序來獲取token值,然后自己定義變量來渲染到form中,這個也是可以的)。具體的做法是通過修改配置文件來關(guān)閉,我這里使用的是SpringBoot開發(fā)的項目,配置文件直接寫在配置類中,通過.csrf().disable()來關(guān)閉。不過這種方案,會迎來CSRF攻擊,不建議在生產(chǎn)環(huán)境中使用,如果系統(tǒng)對外界做了隔離,這樣做也是可以的。大部分的生產(chǎn)環(huán)境采用的也多是這種方案。

          上面三種解決方案都可以解決登錄不成功的問題。

          配置登錄成功后的默認(rèn)頁面

          現(xiàn)在security登錄成功后默認(rèn)會跳轉(zhuǎn)到一個路徑,這個路徑就是登錄鏈接去掉后面的/login,這個默認(rèn)跳轉(zhuǎn)也是可以配置的:

          然后再把默認(rèn)頁面改為/home路徑:

          現(xiàn)在我們登錄成功,跳轉(zhuǎn)的就是/home:

          配置登出

          除了登錄,security還有自帶的登出,即退出系統(tǒng)功能,默認(rèn)路徑就是/logout。我們可以在home頁面中加一個登出操作:

          退出后,默認(rèn)進(jìn)入的自然是登錄頁面,但是瀏覽器路徑上面,要顯示出剛才是退出系統(tǒng)了。所以應(yīng)該顯示的路徑是/login?logout,但是由于這個路徑?jīng)]有授權(quán),會再次跳轉(zhuǎn)到登錄頁面,顯示的也就還是/login,所以我們對登出也要進(jìn)行授權(quán):

          現(xiàn)在顯示的就是正常的退出后的路徑:

          代碼地址 : https://gitee.com/blueses/spring-boot-security 03


          主站蜘蛛池模板: 亚洲愉拍一区二区三区| 一区二区三区人妻无码| 波多野结衣中文字幕一区| 一区二区三区视频| 无码中文字幕乱码一区 | 中文字幕AV一区二区三区人妻少妇| 精品人妻一区二区三区四区| 无码视频一区二区三区| 欧洲精品码一区二区三区| 国产激情一区二区三区在线观看| 理论亚洲区美一区二区三区| 免费观看日本污污ww网站一区 | 成人精品一区二区三区校园激情 | 国模丽丽啪啪一区二区| 日韩精品无码视频一区二区蜜桃| 免费萌白酱国产一区二区三区| 国模精品一区二区三区| 国产AV一区二区三区传媒| 日韩免费无码一区二区三区| 亚洲一区中文字幕在线观看| 亚洲国产精品无码第一区二区三区| 免费无码A片一区二三区| 国产麻豆剧果冻传媒一区| av在线亚洲欧洲日产一区二区| 国内精品无码一区二区三区 | 消息称老熟妇乱视频一区二区| 精品三级AV无码一区| 亚洲AV成人一区二区三区观看| 日本精品高清一区二区2021| 亚洲国产精品一区二区第一页免| av无码人妻一区二区三区牛牛| 亚洲无圣光一区二区| 成人无号精品一区二区三区| 亚洲免费一区二区| 亚洲成在人天堂一区二区| 精品免费国产一区二区三区| 成人国产一区二区三区| 射精专区一区二区朝鲜| 日本精品高清一区二区2021| 97久久精品一区二区三区| 人妻av无码一区二区三区|