全网整合营销服务商

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

免费咨询热线:400-708-3566

Ajax实现注册并选择头像后上传功能

在初次接触ajax后,我们做了一个crm训练的项目,大多数小组都有注册用户这一项,但是都忽略掉了一个功能,那就是,很多网站的注册是可以上传头像的,在这里我做了一个在已有的头像数组里选择图片上传作头像的小型crm(当然,可以从本地照片上传并裁剪的那种我还没做出来,不过只要有时间我就会研究的,相信时间也不会太久的)。

1.先写出一个注册页面以及css样式我命名为regist.html,css文件名为regist.css,在这里我省略掉具体代码,上图看效果吧:(页面有点丑,别介意)

还有一个用于显示添加后记录的information.html页面,此时只有表头:

2.写出创建连接池模块(dbutil.js),也即是建立链接的js文件,我在这里建的是users_infor表,使用的数据库是test。

var mysql = require('mysql');
var pool = mysql.createPool({
host : 'localhost',
user : 'root',
password : 'lovo',
database:"test",
port:3306
});
exports.pool=pool;

3.写出模块用来连接数据库,处理(增删改查)用户数据(Userdao.js),里面把操作数据库的函数一律命名为getAllUser:

var db = require("../DBUtil/dbutil.js");
//var conn = db.conn;
var mypool =db.pool;
function getAllUser(sql,arg,fun){
mypool.getConnection(function(err,conn){
conn.query(sql,arg,fun);
conn.end();
})
}
exports.getAllUser=getAllUser;

4.写出操作数据库的模块,也即是对数据表的增,删,改,查(Userservice.js):

var dao = require("../dao/UserDao.js");

定义注册函数,即往数据表user_infor添加新纪录的函数

exports.regist = function(req,res){
var arg;
if (req.method == "get" || req.method == "GET") {
arg = [req.query.username, req.query.pwd, req.query.pics];
} else {
arg = [req.body.username, req.body.pwd, req.body.pics];
}
var sql = "insert into user_infor(u_name,u_pwd,u_pics) values(?,?,?)"
dao.getAllUser(sql, arg, function (err, result) {
if (err) {
console.log(err);
} else {
if (result.affectedRows>0){
res.sendfile("./static/html/information.html")
} else {
res.sendfile("./static/html/regist.html")
}
}
})
}

定义显示information.html页面所有记录的函数,即查询user_infor表所有内容的函数

exports.listAll=function(req,res){
var sql = " select * from user_infor ";
dao.getAllUser(sql,function (err, result, fields) {
if (err){
console.log(err);
} else {
if (result.length>0){
res.json(result);console.log(result)
} else {
res.send("failed");
}
}
})
}

5.当然,不要忘了引入2个模块express和mysql,新建一个文件夹node_module,将这2个模块包含在其中。

6.然后,就是写一个主要的js文件了(main.js),也即是跟用户交互的js:

var http = require("http");
var express = require("express");
var userser = require("./route/UserService.js");
var url= require("url");
var app = express();
app.use(express.cookieParser());
app.use(express.session({
secret:"123456",
name:"userLogin",
cookie:{maxAge:9999999}
}))
app.set("port",8888);
app.use(express.static(__dirname+"/static"));
app.use(express.methodOverride());
app.use(express.bodyParser());
app.post("/regist",userser.regist);
app.post("/list",userser.listAll);
http.createServer(app).listen(app.get("port"),function(){
console.log("服务启动成功!监听"+app.get("port")+"端口");
})

7.下面的js文件时针对于regist和information的,分别如下:

--------------------------------regist页面选择头像的函数------------------------------------------------------------

function xuanze() {
var pics=document.getElementById("pics");
var picsdiv = document.getElementById("login_pics");
picsdiv.style.display = 'block';
var img=document.getElementsByTagName("img");
var picarrs=["../img/user1.jpg",
"../img/user2.jpg",
"../img/user3.jpg",
"../img/user4.jpg",
"../img/user5.jpg",
"../img/user6.jpg",
"../img/user7.jpg",
"../img/user8.jpg",
"../img/user9.jpg",
"../img/user10.jpg",
"../img/user11.jpg",
"../img/user12.jpg",
"../img/user13.jpg",
"../img/user14.jpg",
"../img/user15.jpg",
"../img/user16.jpg",
"../img/user17.jpg",
"../img/user18.jpg",
"../img/user19.jpg",
"../img/user20.jpg",
"../img/user21.jpg",
"../img/user22.jpg",
"../img/user23.jpg",
"../img/user24.jpg"];
for(var i=0;i<picarrs.length;i++){
img[i].src=picarrs[i];
}
for(var j=0;j<img.length;j++){
img[j].onclick=function(e){
var target= e.target|| e.srcElement;
var imgroute=target.src;//此处若弹出imgroute,可以看到完全路径是http:localhost:8888/img/users20.jpg
pics.value=".."+imgroute.substr(21);/*此处要截取后面的部分才是图片的路径,前面的http:localhost:8888要省去,不是我们需要的路径,若不截取将无法识别*/
}
}
}

-----------------------information页面显示所有记录的函数,window一加载即全部显示------------------------------------------------

window.onload=function(){
var xmlhttpReq;
if (window.XMLHttpRequest)
xmlhttpReq=new XMLHttpRequest();
else
xmlhttpReq=new ActiveXObject("Microsoft.XMLHTTP");
var url="http://localhost:8888/list";
//初始化信息
xmlhttpReq.open("post",url,true);
//添加请求头
xmlhttpReq.setRequestHeader("Content-type","application/x-www-form-urlencoded");
xmlhttpReq.send(null);
xmlhttpReq.onreadystatechange = function(){
if (xmlhttpReq.readyState==4 && xmlhttpReq.status==200) {
if (xmlhttpReq.responseText != "failed"){
var userinfor = document.getElementById("userinfor");
var users = eval("(" + xmlhttpReq.responseText + ")");
for (var i = 0; i < users.length; i++){
var newRow = userinfor.insertRow();
newRow.style.height = "100px";
newRow.style.backgroundColor = "skyblue";
newRow.insertCell(newRow.cells.length).innerHTML =users[i].u_name;
newRow.insertCell(newRow.cells.length).innerHTML =users[i].u_pwd;
newRow.insertCell(newRow.cells.length).innerHTML ="<img src='"+users[i].u_pics+"'>";//此处要在这个单元格里插入img元素,将提交传过来的路径指定为此img的

src,若没有这个img元素,则此处显示的仍然是路径,将没有图片出现。

newRow.insertCell(newRow.cells.length).innerHTML ="<input type='button' id='del' id='" + users[i].u_id + "' value='删除信息' onclick='shanchu(this)'/>";
}
} else if (xmlhttpReq.responseText == "failed") {
alert("添加新用户失败");
}
}
}
}

8.还有最重要的一点,在数据库中新建user_infor表时,指定user_pics这个字段要指定图片存的路径:

USE test;
DROP TABLE IF EXISTS user_infor;
CREATE TABLE user_infor(
u_id INT PRIMARY KEY AUTO_INCREMENT,
u_name CHAR(20) NOT NULL,
u_pwd CHAR(20) NOT NULL,
u_pics CHAR(100) NOT NULL
)
INSERT INTO user_infor(u_name,u_pwd,u_pics) VALUES
('xiaoming','111111','../img/user12.jpg'),
('xiaofang','222222','../img/user13.jpg'),
('xiaozhou','333333','../img/user14.jpg')

整个工程的文件存放关系如下:

用SQLyog打开数据库,运行main.js后,在浏览器里打开regist.html,开始注册并选择头像:

在某个头像上点击后并返回,头像的text文本框里就生成了图片的路径,如下:

点击提交,就完成了注册,页面跳转到information页面,几次注册成功后页面就显示成下面这样子:

头像也就可以上传了,因为仓促之中写成的,样式不美观,敬请谅解!如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# ajax上传头像  # PHP+ajaxfileupload+jcrop插件完美实现头像上传剪裁  # PHP+Ajax异步带进度条上传文件实例  # 基于jsp的AJAX多文件上传的实例  # jQuery Ajax使用FormData对象上传文件的方法  # jQuery Ajax 上传文件处理方式介绍(推荐)  # jQuery插件uploadify实现ajax效果的图片上传  # 借助FileReader实现将文件编码为Base64后通过AJAX上传  # jquery插件ajaxupload实现文件上传操作  # php+ajax无刷新上传图片实例代码  # 基于HTML5 Ajax文件上传进度条如何实现(jquery版本)  # 通过js获取上传的图片信息(临时保存路径  # 名称  # 大小)然后通过ajax传递给后端的方法  # jQuery异步上传文件插件ajaxFileUpload详细介绍  # 即是  # 命名为  # 格里  # 的是  # 上传  # 这一  # 就会  # 都有  # 在这里  # 我还  # 也就  # 才是  # 在这  # 在此  # 最重要  # 几次  # 要在  # 注册用户  # 弹出  # 可以看到 


相关文章: 如何快速启动建站代理加盟业务?  如何自定义建站之星网站的导航菜单样式?  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  购物网站制作公司有哪些,哪个购物网站比较好?  油猴 教程,油猴搜脚本为什么会网页无法显示?  网站制作公司广州有几家,广州尚艺美发学校网站是多少?  广东专业制作网站有哪些,广东省能源集团有限公司官网?  如何在建站之星绑定自定义域名?  音响网站制作视频教程,隆霸音响官方网站?  网站图片在线制作软件,怎么在图片上做链接?  如何快速搭建虚拟主机网站?新手必看指南  建站之星如何实现五合一智能建站与营销推广?  网站制作模板下载什么软件,ppt模板免费下载网站?  C++时间戳转换成日期时间的步骤和示例代码  常州企业建站如何选择最佳模板?  ,石家庄四十八中学官网?  如何在建站之星网店版论坛获取技术支持?  内部网站制作流程,如何建立公司内部网站?  如何在云主机上快速搭建多站点网站?  北京建设网站制作公司,北京古代建筑博物馆预约官网?  宁波自助建站系统如何快速打造专业企业网站?  免费网站制作appp,免费制作app哪个平台好?  枣阳网站制作,阳新火车站打的到仙岛湖多少钱?  Android自定义控件实现温度旋转按钮效果  上海网站制作网站建设公司,建筑电工证网上查询系统入口?  如何通过远程VPS快速搭建个人网站?  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  建站之星安装后界面空白如何解决?  宝华建站服务条款解析:五站合一功能与SEO优化设置指南  详解jQuery停止动画——stop()方法的使用  建站之星代理平台如何选择最佳方案?  智能起名网站制作软件有哪些,制作logo的软件?  建站主机选购指南与交易推荐:核心配置解析  导航网站建站方案与优化指南:一站式高效搭建技巧解析  建站之星安装模板失败:服务器环境不兼容?  如何用已有域名快速搭建网站?  再谈Python中的字符串与字符编码(推荐)  北京网站制作公司哪家好一点,北京租房网站有哪些?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  安云自助建站系统如何快速提升SEO排名?  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  建站之星安装后如何配置SEO及设计样式?  西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  如何在Golang中使用replace替换模块_指定本地或远程路径  高性能网站服务器部署指南:稳定运行与安全配置优化方案  实惠建站价格推荐:2025年高性价比自助建站套餐解析  武清网站制作公司,天津武清个人营业执照注销查询系统网站?  如何快速搭建高效简练网站?  深圳 网站制作,深圳招聘网站哪个比较好一点啊? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。