整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

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提交文件流。