通过数据库和ajax方法写出地图的实例代码
程序员文章站
2022-04-29 09:25:50
ajax教程
ajax = asynchronous javascript and xml(异步的 javascript 和 xml)。
ajax 不是新的编程语言...
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部分--> <div class="content_map"> <!-- 标题--> <hr class="mleft"/> <span>相关宠物医院</span> <hr class="mright"/> <!-- 左边部分:地图--> <div id="maplist"> </div> <!-- 右边部分点击左边要添加的内容:以及最开始加入的信息--> <div id="map_right"> <div class="shopmsg"> <img src="images/w_map.png"/> <div class="pmname">宠物店名:petjoy宠物社区</div> <div class="address">地址:长宁区机旋路1258号--1260号</div> <div class="phone">电话号码:(021)53018000</div> </div> </div> </div> <!--js代码部分--> <script type="text/javascript"> window.onload=function(){ getmap(); } // 向地图添加信息:ajax function getmap(){ //创建对象 var httpreq; if(window.xmlhttprequest){ httpreq=new xmlhttprequest(); }else{ httpreq=new activexobject("microsoft.xmlhttp"); } var maplist=document.getelementbyid("maplist");//获取地图列表 maplist.innerhtml='';//清空地图里在html里面加的信息 // 定义回调函数,接收从数据库响应回来的数据。 // onreadystatechange():存储函数(或函数名)。每当readystate属性改变时,就会调用该函数 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>'; } } } //发起请求(打开一个地址) httpreq.open("get", "adress.do", true); //发送,如果提交方式为get,发送为null;如果提交方式为post,哪send里写要发送的参数,没得的话,就写null httpreq.send(null); } //点击获取信息 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">宠物店名:'+jsonobj[i].pmname+'</div>'+ '<div class="address">地址:'+jsonobj[i].pmaddress+'</div>'+ '<div class="phone">电话号码:'+jsonobj[i].pmphone+'</div>'+ '</div>' } } } //发起请求 httpreq.open("get", "adressmsg.do?pmid="+a, true); //发送 httpreq.send(null); } </script> </body> </html>
服务端部分:app.js(一个javascript):
var express=require("express");//引用express var mysql=require("mysql");//引用mysql var app=express();//执行express里的全局函数,返回一个express对象 app.configure(function(){ app.use(app.router);//路由,配置路由时,先执行,用户定义的拦截地址 app.use(express.static(__dirname+"/public"));//设置静态资源路径 app.use(express.errorhandler());//开发者模块,将错误显示在html上 }); app.get("/adress.do",function(req,res){ //console.log("d-----------1"); //建立数据库连接,建立桥梁 var myconn=mysql.createconnection({ host:"localhost", port:"3306", user:"root", password:"123456", database:"pet" }); //打开连接 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); }); //关闭连接 myconn.end(); }); //城市点击响应 app.get("/adressmsg.do",function(req,res){ var pmid=req.query.pmid; console.log(pmid); //建立数据库连接,建立桥梁 var myconn=mysql.createconnection({ host:"localhost", port:"3306", user:"root", password:"123456", database:"pet" }); //打开连接 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); }); //关闭连接 myconn.end(); }); //监听端口号 app.listen(8888,function(){//监听 console.log("express监听成功!"); console.log(__dirname); });
数据库mysql信息:
/*创建数据库:pet*/ create database pet; /*宠物店地图*/ create table petmap(/*宠物店*/ pmid int auto_increment primary key,/*宠物店id*/ pmname nvarchar(60),/*宠物店名*/ pmcity nvarchar(20),/*宠物店所在城市*/ pmaddress nvarchar(100),/*宠物店所在详细地址*/ pmimg varchar(60),/*宠物店图片*/ pmphone varchar(30),/*宠物店电话号码*/ pmtop float,/*宠物店位置上面*/ pmleft float/*宠物店位置下面*/ ) /*插入信息*/ insert into petmap(pmname,pmcity,pmaddress,pmimg,pmphone,pmtop,pmleft) values ('邛崃邛临美多宠物服务部','成都','成都市邛崃市长松路296号','map1.png','15202891690',360,320), ('谐和宠物医院','德阳','德阳市旌阳区珠江西路300号','map2.png','0838-6181255',320,350), ('天宁动物医院','西安','西安市新城区韩森路','map3.png','028-81836050',260,240), ('宠美康动物医院','乌鲁木齐','乌鲁木齐市天山区幸福路774号','map4.png','0991-2654158',210,170), ('绵阳康贝动物诊所','绵阳','绵阳市游仙区东津路5-2号','map5.png','0816-2987186',315,335), ('圣心动物医院','重庆','重庆市九龙坡区大公馆九龙大厦3-2','map6.png','023-68820999',360,380), ('吉祥宠物医院(油榨街店)','贵阳','贵阳市南明区油榨街花鸟市场宠物区','map7.png','0851-88275946',400,380), ('常德市武陵区动物医院','常德','常德市武陵区青年路478号','map8.png','0736-7236814',230,393), ('爱尔宠物','郑州','郑州市金水区金水东路3-6号','map9.png','0371-69193157',300,453), ('长沙市博旺宠物诊所','长沙','长沙市天心区西牌楼街41号附近','map10.png','0731-82329801',370,443), ('大嘴狗宠物医院','合肥','合肥市庐阳区北一环与肥西路交口向南','map11.png','0551-64286773',330,500), ('秦皇岛市宠物医院','秦皇岛','秦皇岛市海港区海阳路9号','map12.png','0335-3076769',165,540); insert into petmap(pmname,pmcity,pmaddress,pmimg,pmphone,pmtop,pmleft) values ('乖乖宠宠物医院','天津','天津市河东区万东路77号(近8630医院)','map13.png','13820105131',195,510), ('北京宠物医院','北京','北京市西城区百万庄北里14号','map14.png','010-88377484',198,490), ('爱宠之家宠物医院','哈尔滨','哈尔滨市南岗区鼎新三道街37号','map15.png','0451-82516177',80,625); insert into petmap(pmname,pmcity,pmaddress,pmimg,pmphone,pmtop,pmleft) values ('拉萨妙妙安心宠物诊所','*','拉萨市城关区纳金路城东工商1楼','map16.png','0891-6223291',360,170);
最终结果:
以上所述是小编给大家介绍的通过数据库和ajax方法写出地图的实例代码,希望对大家有所帮助