English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

データベースと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();
}
httpReq=new ActiveXObject("Microsoft.XMLHTTP");
}
var maplist=document.getElementById("maplist");//地図リストを取得します
maplist.innerHTML='';//地図内に追加した情報をクリアします
// コールバック関数を定義し、データベースからの応答データを受け取ります。
// 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();
}
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号1.png','15202891690,360,320),
(谐和宠物医院,德阳,德阳市旌阳区珠江西路)300号,map2.png','0838-6181255',320,350),
(天宁动物医院,西安,西安市新城区韩森路,map)3.png','028-81836050,260,240),
(宠美康动物医院,乌鲁木齐,乌鲁木齐市天山区幸福路)774号4.png','0991-2654158',210,170),
(绵阳康贝动物诊所,绵阳,绵阳市游仙区东津路)5-2号5.png','0816-2987186',315,335),
(圣心动物医院,重庆,重庆市九龙坡区大公馆九龙大厦)3-26.png','023-68820999',360,380),
(吉祥宠物医院(油榨街店),贵阳,贵阳市南明区油榨街花鸟市场宠物区,map)7.png','0851-88275946',400,380),
(常德市武陵区动物医院,常德,常德市武陵区青年路)478号8.png','0736-7236814',230,393),
(爱尔宠物,郑州,郑州市金水区金水东路)3-6号9.png','0371-69193157',300,453),
(长沙市博旺宠物诊所,长沙,长沙市天心区西牌樓街)41号附近,map10.png','0731-82329801',370,443),
(大嘴狗宠物医院,合肥,合肥市庐阳区北一環与肥西路交口向南,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(メール送信時、#を@に変更してください。報告を行い、関連する証拠を提供してください。一旦確認がとれましたら、本サイトは即座に侵害を疑われるコンテンツを削除します。)

おすすめ