Ajax實(shí)現(xiàn)注冊(cè)并選擇頭像后上傳功能
在初次接觸ajax后,我們做了一個(gè)crm訓(xùn)練的項(xiàng)目,大多數(shù)小組都有注冊(cè)用戶這一項(xiàng),但是都忽略掉了一個(gè)功能,那就是,很多網(wǎng)站的注冊(cè)是可以上傳頭像的,在這里我做了一個(gè)在已有的頭像數(shù)組里選擇圖片上傳作頭像的小型crm(當(dāng)然,可以從本地照片上傳并裁剪的那種我還沒做出來,不過只要有時(shí)間我就會(huì)研究的,相信時(shí)間也不會(huì)太久的)。
1.先寫出一個(gè)注冊(cè)頁(yè)面以及css樣式我命名為regist.html,css文件名為regist.css,在這里我省略掉具體代碼,上圖看效果吧:(頁(yè)面有點(diǎn)丑,別介意)
還有一個(gè)用于顯示添加后記錄的information.html頁(yè)面,此時(shí)只有表頭:
2.寫出創(chuàng)建連接池模塊(dbutil.js),也即是建立鏈接的js文件,我在這里建的是users_infor表,使用的數(shù)據(jù)庫(kù)是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ù)庫(kù),處理(增刪改查)用戶數(shù)據(jù)(Userdao.js),里面把操作數(shù)據(jù)庫(kù)的函數(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ù)庫(kù)的模塊,也即是對(duì)數(shù)據(jù)表的增,刪,改,查(Userservice.js):
var dao = require("../dao/UserDao.js");
定義注冊(cè)函數(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頁(yè)面所有記錄的函數(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í)針對(duì)于regist和information的,分別如下:
--------------------------------regist頁(yè)面選擇頭像的函數(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;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要省去,不是我們需要的路徑,若不截取將無法識(shí)別*/ } } }
-----------------------information頁(yè)面顯示所有記錄的函數(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); //添加請(qǐng)求頭 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ù)庫(kù)中新建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ù)庫(kù),運(yùn)行main.js后,在瀏覽器里打開regist.html,開始注冊(cè)并選擇頭像:
在某個(gè)頭像上點(diǎn)擊后并返回,頭像的text文本框里就生成了圖片的路徑,如下:
點(diǎn)擊提交,就完成了注冊(cè),頁(yè)面跳轉(zhuǎn)到information頁(yè)面,幾次注冊(cè)成功后頁(yè)面就顯示成下面這樣子:
頭像也就可以上傳了,因?yàn)閭}(cāng)促之中寫成的,樣式不美觀,敬請(qǐng)諒解!如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- PHP+ajaxfileupload+jcrop插件完美實(shí)現(xiàn)頭像上傳剪裁
- PHP+Ajax異步帶進(jìn)度條上傳文件實(shí)例
- 基于jsp的AJAX多文件上傳的實(shí)例
- jQuery Ajax使用FormData對(duì)象上傳文件的方法
- 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ì)介紹
相關(guān)文章
Ajax 提交表單數(shù)據(jù)到入庫(kù)的全盤操作流程分享
以下是Ajax 提交表單數(shù)據(jù)到入庫(kù)的全盤操作流程,希望本文對(duì)廣大php開發(fā)者有所幫助,感謝閱讀本文2014-01-01重寫 ajax 實(shí)現(xiàn) session 超時(shí)跳轉(zhuǎn)到登錄頁(yè)面實(shí)例代碼
這篇文章主要介紹了重寫 ajax 實(shí)現(xiàn) session 超時(shí)跳轉(zhuǎn)到登錄頁(yè)面實(shí)例代碼,需要的朋友可以參考下2017-05-05國(guó)內(nèi)首發(fā) -- ajax完整功能框架
國(guó)內(nèi)首發(fā) -- ajax完整功能框架2007-01-01pushState實(shí)現(xiàn)Ajax無刷新頁(yè)面切換
這篇文章主要介紹了pushState實(shí)現(xiàn)Ajax無刷新頁(yè)面切換的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11ASP.NET與Ajax的實(shí)現(xiàn)方式小總結(jié)
Ajax 應(yīng)該不是一項(xiàng)技術(shù),是一種思想而已,跟 ASP.NET 以及其它 Web 開發(fā)語(yǔ)言沒有什么太大關(guān)系,這里只是談?wù)?ASP.NET 中目前使用的 Ajax 技術(shù)以及其它一些實(shí)現(xiàn) Ajax 的優(yōu)秀框架。感興趣的朋友跟著小編一起學(xué)習(xí)asp.net與ajax的實(shí)現(xiàn)方式2015-09-09用AJAX實(shí)現(xiàn)頁(yè)面登陸以及注冊(cè)用戶名驗(yàn)證的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)硪黄肁JAX實(shí)現(xiàn)頁(yè)面登陸以及注冊(cè)用戶名驗(yàn)證的簡(jiǎn)單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10使用Ajax實(shí)現(xiàn)簡(jiǎn)單的帶百分比進(jìn)度條實(shí)例
最近做項(xiàng)目遇到這樣的需求要求當(dāng)進(jìn)行文件長(zhǎng)傳保存等操作時(shí),能在頁(yè)面顯示一個(gè)帶百分比的進(jìn)度條,給用戶一個(gè)好的交互體驗(yàn),下面通過實(shí)例代碼給大家介紹基于ajax實(shí)現(xiàn)帶百分比進(jìn)度條效果,需要的的朋友參考下吧2017-07-07關(guān)于多個(gè)Ajax請(qǐng)求執(zhí)行返回先后的問題示例探討
這篇文章主要與大家探討下關(guān)于多個(gè)Ajax請(qǐng)求執(zhí)行返回先后的問題,需要的朋友可以參考下2014-07-07