English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
ajax教程
AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。
AJAX 不是新的编程语言,而是一种使用现有标准的新方法。
AJAX 是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下。
客户端部分:html、js、css代码部分:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title></title> <meta charset="UTF-8"/> </head> <!--css样式部分--> <style type="text/css"> .content_map{ /*border:1px solid blue;*/ width:1349px; height:524px; float:left; margin-top:100px; } .content_map .mLeft{ border: none; border-top:1px solid #fb6c20; width:400px; margin-top:14px; float:left; margin-left:134px; } .content_map>span{ margin-left:20px; margin-right:20px; font-size:28px; font-family: "Microsoft Yahei"; /*font-weight: bold;*/ float:left; } .content_map .mRight{ float:left; border: none; border-top:1px solid #fb6c20; width:400px; margin-top:14px; } #maplist{ margin-top:50px; width:749px; height:524px; /*border:1px solid #fb6c20;*/ background: url("images/diru.png") no-repeat 0 0 ; background-size: contain; position: relative; float:left; } .mapShop img{ position:absolute; /*border:1px solid red;*/ } #map_right{ /*border:1px solid #fb6c20;*/ float:left; /*width:600px;*/ width:594px; height:524px; background-color: #f0f2fe; margin-top: 40px; } .shopMsg img{ width:450px; height:300px; margin-left:72px; margin-top:40px; } .shopMsg .pmname{ color:#000; font-size:20px; margin-top:30px; margin-left:72px; font-family:微软雅黑; } .shopMsg .address{ color:#000; font-size:20px; margin-top:30px; margin-left:72px; font-family:微软雅黑; } .shopMsg .phone{ color:#000; font-size:20px; margin-top:30px; margin-left:72px; font-family:微软雅黑; } </style> <body> <!--html-Teil--> <div class="content_map"> <!-- Titel--> <hr class="mLeft"/> <span>Verwandte Tierkliniken</span> <hr class="mRight"/> <!-- Linker Teil: Karte--> <div id="maplist"> </div> <!-- Klicken Sie auf den linken Teil, um den linken zu hinzuzufügen: sowie die am Anfang hinzugefügten Informationen--> <div id="map_right"> <div class="shopMsg"> <img src="images/w_map.png"/> <div class="pmname">Name des Tierladens: Petjoy Haustiergemeinschaft</div> <div class="address">Adresse: Changningqu Jixuanlu1258Nummer--1260-Nummer</div> <div class="phone">Telefonnummer: (021)53018000</div> </div> </div> </div> <!--js-Code-Teil--> <script type="text/javascript"> window.onload=function(){ getMap(); } // Fügen Sie Informationen zur Karte hinzu: ajax function getMap(){ //Erstellen Sie ein Objekt var httpReq; if(window.XMLHttpRequest){ httpReq=new XMLHttpRequest(); }else{ httpReq=new ActiveXObject("Microsoft.XMLHTTP"); } var maplist=document.getElementById("maplist");//Erhalten Sie die Kartenliste maplist.innerHTML='';//Leeren Sie die Informationen im Kartenbereich, die im HTML hinzugefügt wurden // Definieren Sie eine Rückruffunktion, um die von der Datenbank zurückgegebenen Daten zu empfangen. // onreadystatechange(): Speicherfunktion (oder Funktionsname). Diese Funktion wird aufgerufen, wenn sich der readyState-Attribut ändert httpReq.onreadystatechange=function(){ if(httpReq.readyState==4&&httpReq.status==200){ var jsonobj=JSON.parse(httpReq.responseText); console.log(jsonobj.length); for (var i = 0; i< jsonobj.length;i++) { maplist.innerHTML+'<div class="mapShop">'+ '<img src="images/fi1.png" style="top:'+jsonobj[i].pmTop+"px"+';left:'+jsonobj[i].pmLeft+"px"+'"/'>+ '<div id="pmcity"+i+'" onclick="getMessage('+i+')" style="top:'+jsonobj[i].pmTop+"px"+';left:'+jsonobj[i].pmLeft+"px"+';position:absolute;padding-top:20px;+'">' + jsonobj[i].pmCity + </div>'+ </div>'; } } } //Senden Sie eine Anfrage (Öffnen Sie eine Adresse) httpReq.open("get", "adress.do", true); //Senden, wenn die Übermittlungsart get ist, senden Sie null; wenn die Übermittlungsart post ist, schreiben Sie die zu sendenden Parameter in das send, wenn es keine gibt, schreiben Sie null httpReq.send(null); } //Information abrufen function getMessage(a){ console.log("M----------1"); var httpReq; if(window.XMLHttpRequest){ httpReq=new XMLHttpRequest(); }else{ httpReq=new ActiveXObject("Microsoft.XMLHTTP"); } var map_right=document.getElementById("map_right"); map_right.innerHTML=''; httpReq.onreadystatechange=function(){ if(httpReq.readyState==4&&httpReq.status==200){ var jsonobj=JSON.parse(httpReq.responseText); console.log(jsonobj.length); for(var i=0;i<jsonobj.length;i++){ map_right.innerHTML+'<div class="shopMsg">'+ '<img src="images/'+jsonobj[i].pmImg+'"/'>+ '<div class="pmname">Tierhandlung Name:'+jsonobj[i].pmName+</div>'+ <div class="address">Adresse:'+jsonobj[i].pmAddress+</div>'+ <div class="phone">Telefonnummer:'+jsonobj[i].pmPhone+</div>'+ </div>' } } } //Anfrage starten httpReq.open("get", "adressMsg.do?pmId="+a, true); //Senden httpReq.send(null); } </script> </body> </html>
Serverseitiger Teil: app.js (ein JavaScript):
var express=require("express");//express einbinden var mysql=require("mysql");//mysql einbinden var app=express();//Ausführen der globalen Funktion in express, Rückgabe eines express-Objekts app.configure(function(){ app.use(app.router);//Routen, bei der Konfiguration der Routen zuerst ausführen, Benutzerdefinierte Interception-Adresse app.use(express.static(__dirname+"/public"));//Statische Ressourcenpfad festlegen app.use(express.errorHandler());//Entwicklermodul, Fehler auf der html-Ansicht anzeigen ); app.get("/adress.do",function(req,res){ //console.log("d-----------1"); //Datenbankverbindung herstellen, Brücke aufbauen var myconn=mysql.createConnection({ host:"localhost", port:"3306, user:"root", password:"123456, database:"pet" ); //Verbindung öffnen myconn.connect(); var sql="SELECT * FROM petmap"; //console.log(sql); myconn.query(sql,[],function(err,data){ //console.log(err); //console.log(data); res.send(data); ); //Verbindung schließen myconn.end(); ); //Stadt klicken, Antwort app.get("/adressMsg.do",function(req,res){ var pmId=req.query.pmId; console.log(pmId); //Datenbankverbindung herstellen, Brücke aufbauen var myconn=mysql.createConnection({ host:"localhost", port:"3306, user:"root", password:"123456, database:"pet" ); //Verbindung öffnen myconn.connect(); console.log("f------------1"); var sql="SELECT * FROM petmap WHERE pmId=?"; console.log(sql); var id=parseInt(pmId); myconn.query(sql,[id+1],function(err,data){ console.log(err); console.log(data); res.send(data); ); //Verbindung schließen myconn.end(); ); //Anhörport app.listen(8888,function(){//Anhören console.log("express wird angehört!"); console.log(__dirname); );
Datenbankmysql-Informationen:
/*Datenbank erstellen: pet*/ CREATE DATABASE pet; /*Haustierladen Karte*/ CREATE TABLE petmap(/*Haustierladen*/ pmId INT AUTO_INCREMENT PRIMARY KEY,/*ID des Haustierladens*/ pmName NVARCHAR(60),/*Name des Haustierladens*/ pmCity NVARCHAR(20),/*Stadt des Haustierladens*/ pmAddress NVARCHAR(100),/*Detaillierte Adresse des Haustierladens*/ pmImg VARCHAR(60),/*Bilder des Haustierladens*/ pmPhone VARCHAR(30),/*Telefonnummer des Haustierladens*/ pmTop FLOAT,/*Über der Lage des Haustierladens*/ pmLeft FLOAT/*Unter der Lage des Haustierladens*/ ) /*Einfügen von Informationen*/ INSERT INTO petmap(pmName,pmCity,pmAddress,pmImg,pmPhone,pmTop,pmLeft) VALUES ('Qionglai Qionglai Meiduo Haustierserviceabteilung','Chengdu','Chengdu Shi Qionglai Qu Changsong Lu')296号1.png','15202891690,360,320), ('Xiehe Haustierklinik','Deyang','Deyang Shi Jingyang Qu Zhijiang Xi Lu')3002.png','0838-6181255',320,350), ('Tianning Dongwu Yiyuan','Xi'an','Xi'an Shi Xincheng Qu Hanshen Lu','map')3.png','028-81836050,260,240), ('Chongmeikang Dongwu Yiyuan','Wulumuqi','Wulumuqi Shi Tianshan Qu Xingfu Lu')774号4.png','0991-2654158',210,170), ('Mianyang Kangbei Dongwu Zhen','Mianyang','Mianyang Shi Youxian Qu Dongjin Lu')5-2号5.png','0816-2987186',315,335), ('Shengxin Dongwu Yiyuan','Chongqing','Chongqing Shi Jiulongpo Qu Dagongguan Jiulong DaSha')3-26.png','023-68820999',360,380), ('Jixiang Haustierklinik (Youzhajie Geschäfte)','Guiyang','Guiyang Shi Nanming Qu Youzhajie Nonghua Shichang Haustierqu','map')7.png','0851-88275946',400,380), ('Changde Shi Wuling Qu Dongwu Yiyuan','Changde','Changde Shi Wuling Qu Qingnian Lu')478号8.png','0736-7236814',230,393), ('Aier Haustier','Zhengzhou','Zhengzhou Shi Jinsui Qu Jinsui Donglu')3-6号9.png','0371-69193157',300,453), ('Changsha Bo Wang Haustierarztpraxis','Changsha','Changsha Shi Tianxin Qu Xipailou Jie')41in der Nähe10.png','0731-82329801',370,443), ('Großmaul Hund Tierklinik','Hefei','Hefei Shi Luyang Qu Beiyi Huan Yu Feixi Road jiaojiao Xiang Nan','map')11.png','0551-64286773',330,500), ('秦皇岛市宠物医院','秦皇岛','秦皇岛市海港区海阳路9号12.png','0335-3076769',165,540); INSERT INTO petmap(pmName,pmCity,pmAddress,pmImg,pmPhone,pmTop,pmLeft) VALUES ('乖乖宠宠物医院','天津','天津市河东区万东路77号(近8630医院)13.png','13820105131',195,510), ('北京宠物医院','北京','北京市西城区百万庄北里14号14.png','010-88377484',198,490), ('爱宠之家宠物医院','哈尔滨','哈尔滨市南岗区鼎新三道街37号15.png','0451-82516177',80,625); INSERT INTO petmap(pmName,pmCity,pmAddress,pmImg,pmPhone,pmTop,pmLeft) VALUES ('拉萨妙妙安心宠物诊所','西藏','拉萨市城关区纳金路城东工商1楼16.png','0891-6223291',360,170);
最终结果:
以上所述是小编为大家介绍的通过数据库和AJAX方法编写地图实例代码,希望对大家有所帮助。如果大家有任何疑问,欢迎给我留言,我会及时回复大家的。在此也非常感谢大家对呐喊教程网站的支持!
声明:本文内容来源于互联网,版权归原作者所有。内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#oldtoolbag.com(在发送邮件时,请将#更换为@进行举报,并提供相关证据。一经查实,本站将立即删除涉嫌侵权内容。)