主頁 > 知識庫 > Ajax實(shí)現(xiàn)注冊并選擇頭像后上傳功能

Ajax實(shí)現(xiàn)注冊并選擇頭像后上傳功能

熱門標(biāo)簽:立陶宛地圖標(biāo)注 河間市地圖標(biāo)注app 上海企業(yè)外呼系統(tǒng)價(jià)錢 中國地圖標(biāo)注不明確情況介紹表 大眾點(diǎn)評400電話怎么申請 電銷機(jī)器人 長春 怎樣在地圖標(biāo)注文字 地圖標(biāo)注推銷坑人 東平縣地圖標(biāo)注app

在初次接觸ajax后,我們做了一個(gè)crm訓(xùn)練的項(xiàng)目,大多數(shù)小組都有注冊用戶這一項(xiàng),但是都忽略掉了一個(gè)功能,那就是,很多網(wǎng)站的注冊是可以上傳頭像的,在這里我做了一個(gè)在已有的頭像數(shù)組里選擇圖片上傳作頭像的小型crm(當(dāng)然,可以從本地照片上傳并裁剪的那種我還沒做出來,不過只要有時(shí)間我就會(huì)研究的,相信時(shí)間也不會(huì)太久的)。

1.先寫出一個(gè)注冊頁面以及css樣式我命名為regist.html,css文件名為regist.css,在這里我省略掉具體代碼,上圖看效果吧:(頁面有點(diǎn)丑,別介意)

還有一個(gè)用于顯示添加后記錄的information.html頁面,此時(shí)只有表頭:

2.寫出創(chuàng)建連接池模塊(dbutil.js),也即是建立鏈接的js文件,我在這里建的是users_infor表,使用的數(shù)據(jù)庫是test。

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

3.寫出模塊用來連接數(shù)據(jù)庫,處理(增刪改查)用戶數(shù)據(jù)(Userdao.js),里面把操作數(shù)據(jù)庫的函數(shù)一律命名為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.寫出操作數(shù)據(jù)庫的模塊,也即是對數(shù)據(jù)表的增,刪,改,查(Userservice.js):

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

定義注冊函數(shù),即往數(shù)據(jù)表user_infor添加新紀(jì)錄的函數(shù)

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頁面所有記錄的函數(shù),即查詢user_infor表所有內(nèi)容的函數(shù)

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.當(dāng)然,不要忘了引入2個(gè)模塊express和mysql,新建一個(gè)文件夾node_module,將這2個(gè)模塊包含在其中。

6.然后,就是寫一個(gè)主要的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("服務(wù)啟動(dòng)成功!監(jiān)聽"+app.get("port")+"端口");
})

7.下面的js文件時(shí)針對于regist和information的,分別如下:

--------------------------------regist頁面選擇頭像的函數(shù)------------------------------------------------------------

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;ipicarrs.length;i++){
img[i].src=picarrs[i];
}
for(var j=0;jimg.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頁面顯示所有記錄的函數(shù),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+"'>";//此處要在這個(gè)單元格里插入img元素,將提交傳過來的路徑指定為此img的

src,若沒有這個(gè)img元素,則此處顯示的仍然是路徑,將沒有圖片出現(xiàn)。

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.還有最重要的一點(diǎn),在數(shù)據(jù)庫中新建user_infor表時(shí),指定user_pics這個(gè)字段要指定圖片存的路徑:

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')

整個(gè)工程的文件存放關(guān)系如下:

用SQLyog打開數(shù)據(jù)庫,運(yùn)行main.js后,在瀏覽器里打開regist.html,開始注冊并選擇頭像:

在某個(gè)頭像上點(diǎn)擊后并返回,頭像的text文本框里就生成了圖片的路徑,如下:

點(diǎn)擊提交,就完成了注冊,頁面跳轉(zhuǎn)到information頁面,幾次注冊成功后頁面就顯示成下面這樣子:

頭像也就可以上傳了,因?yàn)閭}促之中寫成的,樣式不美觀,敬請諒解!如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • PHP+ajaxfileupload+jcrop插件完美實(shí)現(xiàn)頭像上傳剪裁
  • PHP+Ajax異步帶進(jìn)度條上傳文件實(shí)例
  • 基于jsp的AJAX多文件上傳的實(shí)例
  • jQuery Ajax使用FormData對象上傳文件的方法
  • jQuery Ajax 上傳文件處理方式介紹(推薦)
  • jQuery插件uploadify實(shí)現(xiàn)ajax效果的圖片上傳
  • 借助FileReader實(shí)現(xiàn)將文件編碼為Base64后通過AJAX上傳
  • jquery插件ajaxupload實(shí)現(xiàn)文件上傳操作
  • php+ajax無刷新上傳圖片實(shí)例代碼
  • 基于HTML5 Ajax文件上傳進(jìn)度條如何實(shí)現(xiàn)(jquery版本)
  • 通過js獲取上傳的圖片信息(臨時(shí)保存路徑,名稱,大小)然后通過ajax傳遞給后端的方法
  • jQuery異步上傳文件插件ajaxFileUpload詳細(xì)介紹

標(biāo)簽:四川 遼寧 本溪 營口 內(nèi)江 玉樹 銅川 益陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Ajax實(shí)現(xiàn)注冊并選擇頭像后上傳功能》,本文關(guān)鍵詞  Ajax,實(shí)現(xiàn),注冊,并,選擇,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Ajax實(shí)現(xiàn)注冊并選擇頭像后上傳功能》相關(guān)的同類信息!
  • 本頁收集關(guān)于Ajax實(shí)現(xiàn)注冊并選擇頭像后上傳功能的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章