Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537
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世界。
TML頁面功能的使用(Webserver):
通過SIMATIC HMI 面板集成的HTML頁面功能將HMI設備組態為HTTP服務器,實現PC端與精智面板之間的文件傳遞等功能。
1. 功能組態
需注意:HTML頁面功能僅支持精智面板(Comfort Panel)和二代移動面板(2nd Mobile Panel)。
在觸摸屏項目"運行系統設置"的“服務”中激活HTML頁面功能:
2. 功能設置
把要監控的數據在 觸摸屏變量表里找到屬性勾選優良生產規范;
下載項目至實際硬件后,在觸摸屏控制面板的“WinCC Internet Settings”中會增加"Web Server"選項; win+c 可以進入觸摸屏設置;
在"Tag authenticate"組中確定訪問服務器操作設備變量的驗證方式,“No authentication”為無需驗證,“Authentication required”為訪問需要密碼。
在“Tag acces”組中確定訪問服務器操作設備變量的方式,“Read/write”為讀取訪問和寫訪問,“Read Only”為讀取訪問。
點擊“User Administration”按鈕進入“UserDatabase-Edit”界面,如下圖所示。自行設置默認用戶“Administrator”的密碼和確認密碼,密碼和確認密碼必須保持一致。如果需要登錄新的用戶,可以點擊"New"按鈕新建用戶,同時輸入用戶名和密碼后,點擊“Apply”確認設置。
3. 功能使用
在PC端使用瀏覽器進行訪問,在瀏覽器地址欄中輸入https://觸摸屏的IP地址,例如:https://192.168.101.120。輸入設置的用戶名和密碼。需注意:用戶名是區分大小寫的。如果需要瀏覽外部存儲介質的文件,例如下載或者上傳文件,點擊“File Browser”就可以看到存儲介質。
前面無論是使用默認配置,還是自定義配置類,都是使用的springboot-security自帶的登錄頁面,自帶的登錄頁面在這個版本雖然設計的非常不錯,但是在實際開發中,我們通常還是使用自己的登錄頁面。下面來寫一個非常簡單的登錄頁面:
這個頁面只有填寫用戶名和密碼的地方,然后就是一個form表單提交,沒有任何其他內容。特別注意!!這里頁面雖然引入了thymeleaf模板,但是沒有使用thymeleaf的任何標簽屬性,使用的是原生的html標簽。繼續下面,然后是定義登錄頁面的路徑:
這樣登錄頁面就添加完成了。
在配置類中添加自定義登錄頁面很簡單,定義登錄頁面鏈接即可:
配置完成后,啟動項目,訪問登錄頁面,可以看到這樣一個錯誤:
顯示重定向次數過多。原來前面我們授權配置的時候,所有自定義的路徑在未登錄的情況下,都會重定向到登錄頁面,現在登錄路徑也是自定義的,所以它一直在自我重定向。登錄路徑本身要配置成不需要授權就能訪問的路徑才合理。配置方式很簡單,只需要加上一個 permitAll 方法即可:
現在重啟項目,訪問登錄可以正常訪問,輸入賬號也可以正常訪問了!
上面的頁面和配置類修改好了以后,輸入賬號登錄,卻發現登錄一直不成功,總是會跳轉到登錄頁面。這是什么原因呢?上面的提到了頁面使用的是原生的html標簽,沒有使用thymeleaf模板的屬性。先說這種原生的情況,之所以登錄不成功,原因是Spring Security默認是開啟CSRF的,所以需要請求中包含CSRF的token信息,在其官方文檔中,提供了在form中嵌入一個hidden標簽來獲取token信息,其原理是,hidden標簽使用了Spring Security提供的標簽,即${csrf.parameterName}、${csrf.token}, 后臺頁面渲染過程中,將此標簽解所對應的值解析出來,這樣,我們的form表單,就嵌入了Spring Security的所需的token信息,在后續的提交登錄請求時,就不會出現沒有CSRF token的異常。做法如下:
這時候登錄,就發現可以成功。在springboot2.1.x版本下,還有第二種更好的解決方案,就是使用thymeleaf模板的form標簽屬性:
在form標簽中,使用th:action屬性,這樣會在表單中默認添加一個hidden的input標簽,效果和第一種解決方式類似,查看源碼,就可以看到:
另外,還有一個解決辦法是,通過關閉CSRF來解決,這個幾乎在任何場景中都能解決這個問題(上面這個解決方案,可能在某些渲染模板不能解析出來token值,不過可以通過后臺程序來獲取token值,然后自己定義變量來渲染到form中,這個也是可以的)。具體的做法是通過修改配置文件來關閉,我這里使用的是SpringBoot開發的項目,配置文件直接寫在配置類中,通過.csrf().disable()來關閉。不過這種方案,會迎來CSRF攻擊,不建議在生產環境中使用,如果系統對外界做了隔離,這樣做也是可以的。大部分的生產環境采用的也多是這種方案。
上面三種解決方案都可以解決登錄不成功的問題。
現在security登錄成功后默認會跳轉到一個路徑,這個路徑就是登錄鏈接去掉后面的/login,這個默認跳轉也是可以配置的:
然后再把默認頁面改為/home路徑:
現在我們登錄成功,跳轉的就是/home:
除了登錄,security還有自帶的登出,即退出系統功能,默認路徑就是/logout。我們可以在home頁面中加一個登出操作:
退出后,默認進入的自然是登錄頁面,但是瀏覽器路徑上面,要顯示出剛才是退出系統了。所以應該顯示的路徑是/login?logout,但是由于這個路徑沒有授權,會再次跳轉到登錄頁面,顯示的也就還是/login,所以我們對登出也要進行授權:
現在顯示的就是正常的退出后的路徑:
代碼地址 : https://gitee.com/blueses/spring-boot-security 03
*請認真填寫需求信息,我們會在24小時內與您取得聯系。