>웹 프론트엔드 >JS 튜토리얼 >Ajax는 새로 고침되지 않는 팝업 도시 선택 기능 코드를 구현합니다.

Ajax는 새로 고침되지 않는 팝업 도시 선택 기능 코드를 구현합니다.

亚连
亚连원래의
2018-05-25 10:27:551472검색

이 글에서는 주로 팝업 비새로 고침 도시 선택 기능 코드의 Ajax 구현을 소개합니다. Ajax 팝업 창 관련 기술과 새로 고침이 없는 선택 데이터 항목을 예제와 함께 분석합니다.

이 기사에서는 도시 선택 기능을 새로 고치지 않는 Ajax 팝업 구현의 예를 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 자세한 내용은 다음과 같습니다.

이것은 전국적인 도시 선택 효과입니다. 도시를 추가할 때 먼저 그룹을 추가하세요. 선택 태그 아래에서 "selectSub"라는 ID를 찾아 옵션 태그를 추가하면 값 속성이 증가합니다. ID "selectSub"를 찾으십시오. 원래 형식에 따라 p를 추가하면 해당 id 속성이 증가한 다음 보조 하위 선택 상자 옵션을 추가하십시오. "selectSub" 아래에 있는 입력 레이블의 ID를 복사하여 필요한 곳에 붙여 넣으십시오. 확장하려면 동적 언어를 사용하여 완료하세요. 도시는 데이터베이스에서 읽을 수 있습니다.

런닝 효과 스크린샷은 다음과 같습니다.

구체적인 코드는 다음과 같습니다.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Ajax弹出式无刷新城市选择特效</title>
<meta http-equiv="content-type" content="text/html;charset=gb2312">
<style type="text/css">
BODY {
 FONT-SIZE: 12px; PADDING-TOP: 50px
}
H2 {
 PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: 12px; PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-TOP: 0px
}
.bton {
 BORDER-RIGHT: #ccc 1px solid; BORDER-TOP: #ccc 1px solid; BACKGROUND: #ddd; BORDER-LEFT: #ccc 1px solid; BORDER-BOTTOM: #ccc 1px solid
}
.cont {
 PADDING-RIGHT: 10px; PADDING-LEFT: 10px; PADDING-BOTTOM: 10px; PADDING-TOP: 10px
}
#main {
 MARGIN: 0px auto; WIDTH: 400px
}
#selectItem {
 BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; MARGIN-TOP: 10px; Z-INDEX: 2; BACKGROUND: #fff; OVERFLOW: hidden; BORDER-LEFT: #000 1px solid; WIDTH: 400px; BORDER-BOTTOM: #000 1px solid; POSITION: absolute; TOP: 0px
}
#preview {
 BORDER-RIGHT: #ccc 1px solid; BORDER-TOP: #ccc 1px solid; MARGIN: 1px; BORDER-LEFT: #ccc 1px solid; BORDER-BOTTOM: #ccc 1px solid
}
#result {
 BORDER-RIGHT: #ccc 1px solid; BORDER-TOP: #ccc 1px solid; MARGIN-TOP: 10px; BORDER-LEFT: #ccc 1px solid; BORDER-BOTTOM: #ccc 1px solid
}
.tit {
 PADDING-LEFT: 10px; MARGIN: 1px; LINE-HEIGHT: 20px; HEIGHT: 20px
}
.bgc_ccc {
 BACKGROUND: #ccc
}
.bgc_eee {
 BACKGROUND: #eee
}
.c_999 {
 COLOR: #999
}
.pointer {
 CURSOR: pointer
}
.left {
 FLOAT: left
}
.right {
 FLOAT: right
}
.cls {
 CLEAR: both; FONT-SIZE: 0px; OVERFLOW: hidden; HEIGHT: 0px
}
#bg {
 DISPLAY: none; Z-INDEX: 1; BACKGROUND: #ccc; FILTER: alpha(opacity=70); LEFT: 0px; WIDTH: 100%; POSITION: absolute; TOP: 0px; opacity: 0.7
}
.hidden {
 DISPLAY: none
}
.move {
 CURSOR: move
}
</style>
</head>
<body>
<p id="main">
 <INPUT class="bton pointer" onclick="openBg(1);openSelect(1)" type="button" value="请选择" name="button">
 <p id="result">
 <p class="tit bgc_eee">
 <H2>您已选择的城市汇总</H2>
 </p>
 <p class="cont" id="makeSureItem"></p>
 </p>
</p>
<p id="bg"></p>
<p class="hidden" id="selectItem">
 <p class="tit bgc_ccc move" onmousedown="drag(event,this)">
 <H2 class="left">请选择城市:</H2>
 <SPAN class="pointer right" onclick="openBg(0);openSelect(0);">[取消]</SPAN>
 <SPAN class="pointer right" onclick="makeSure();">[确定]</SPAN>
 </p>
 <p class="cls"></p>
 <p class="cont">
 <p id="selectSub">
 <SELECT style="MARGIN-BOTTOM: 10px" onchange="showSelect(this.value)" name="">
 <OPTION value="0" selected>中国名城</OPTION> 
 <OPTION value="1">魅力城市</OPTION>
 <OPTION value="2">东北三省</OPTION>
 <OPTION value="3">世界城市</OPTION>
 </SELECT> 
 <p id="c00">
 <INPUT onclick="addPreItem()" type="checkbox" value="北京" name="ck00">北京
 <INPUT onclick="addPreItem()" type="checkbox" value="福建" name="ck00">福建
 <INPUT onclick="addPreItem()" type="checkbox" value="四川" name="ck00">四川
 <INPUT onclick="addPreItem()" type="checkbox" value="江苏" name="ck00">江苏
 </p>
 <p id="c01">
 <INPUT onclick="addPreItem()" type="checkbox" value="上海" name="ck01">上海
 <INPUT onclick="addPreItem()" type="checkbox" value="云南" name="ck01">云南
 <INPUT onclick="addPreItem()" type="checkbox" value="贵州" name="ck01">贵州
 </p>
 <p id="c02">
 <INPUT onclick="addPreItem()" type="checkbox" value="黑龙江" name="ck01">黑龙江
 <INPUT onclick="addPreItem()" type="checkbox" value="吉林" name="ck01">吉林
 <INPUT onclick="addPreItem()" type="checkbox" value="辽宁" name="ck01">辽宁
 </p>
 <p id="c03">
 <INPUT onclick="addPreItem()" type="checkbox" value="美国" name="ck01">美国
 <INPUT onclick="addPreItem()" type="checkbox" value="阿富汗" name="ck01">阿富汗
 <INPUT onclick="addPreItem()" type="checkbox" value="日本" name="ck01">日本
 </p>
 </p>
 </p>
 <p id="preview">
 <p class="tit bgc_eee c_999">
 <H2>您已选择:</H2>
 </p>
 <p class="cont" id="previewItem"></p>
 </p>
</p>
<script type="text/javascript">
var grow = $("selectSub").getElementsByTagName("option").length; //组数
var showGrow = 0;//已打开组
var selectCount = 0; //已选数量 
showSelect(showGrow);
var items = $("selectSub").getElementsByTagName("input");
function $(o){
 if(typeof(o) == "string")
 return document.getElementById(o);
 return o;
}
function openBg(state){
 if(state == 1)
 {
  $("bg").style.display = "block";
  var h = document.body.offsetHeight > document.documentElement.offsetHeight ? document.body.offsetHeight : document.documentElement.offsetHeight;
  $("bg").style.height = h + "px";
 }
 else
 {
  $("bg").style.display = "none";
 } 
}
function openSelect(state){
 if(state == 1) 
 {
  $("selectItem").style.display = "block";
  $("selectItem").style.left = ($("bg").offsetWidth - $("selectItem").offsetWidth)/2 + "px";
  $("selectItem").style.top = document.body.scrollTop + 100 + "px";  
 }
 else
 {
  $("selectItem").style.display = "none";
 }
}
function showSelect(id){
 for(var i = 0 ; i < grow ;i++)
 {
  $("c0" + i).style.display = "none";
 }
 $("c0" + id).style.display = "block";
 showGrow = id;
}
function open(id,state){ 
 if(state == 1)
 $(id).style.display = "block";
 $(id).style.diaplay = "none";
}
function addPreItem(){ 
 $("previewItem").innerHTML = "";
 var len = 0 ;
 for(var i = 0 ; i < items.length ; i++)
 {
  if(items[i].checked == true)
  {
   var mes = "<input type=&#39;checkbox&#39; checked=&#39;true&#39; value=&#39;"+ items[i].value +"&#39; onclick=&#39;copyItem(\"previewItem\",\"previewItem\");same(this);&#39;>" + items[i].value;
   $("previewItem").innerHTML += mes;
  }
 }
}
function makeSure(){
 openBg(0);
 openSelect(0);
 copyItem("previewItem","makeSureItem") 
}
function copyHTML(id1,id2){
 $(id2).innerHTML = $("id1").innerHTML;
}
function copyItem(id1,id2){
 
 var mes = "";
 var items2 = $(id1).getElementsByTagName("input");
 for(var i = 0 ; i < items2.length ; i++)
 {
  if(items2[i].checked == true)
  {
  mes += "<input type=&#39;checkbox&#39; checked=&#39;true&#39; value=&#39;"+ items2[i].value +"&#39; onclick=&#39;copyItem(\"" + id2+ "\",\""+ id1 +"\");same(this);&#39;>" + items2[i].value;   
  }
 }
 $(id2).innerHTML = "";
 $(id2).innerHTML += mes;
}
function same(ck){
 for(var i = 0 ; i < items.length ; i++)
 {
  if(ck.value == items[i].value)
  {
   items[i].checked = ck.checked;
  }
 }
} 
var oDrag = "";
var ox,oy,nx,ny,dy,dx;
function drag(e,o){
 var e = e ? e : event;
 var mouseD = document.all ? 1 : 0;
 if(e.button == mouseD)
 {
  oDrag = o.parentNode;
  ox = e.clientX;
  oy = e.clientY;  
 }
}
function dragPro(e){
 if(oDrag != "")
 { 
  var e = e ? e : event;
  dx = parseInt($(oDrag).style.left);
  dy = parseInt($(oDrag).style.top);
  nx = e.clientX;
  ny = e.clientY;
  $(oDrag).style.left = (dx + ( nx - ox )) + "px";
  $(oDrag).style.top = (dy + ( ny - oy )) + "px";
  ox = nx;
  oy = ny;
 }
}
document.onmouseup = function(){oDrag = "";}
document.onmousemove = function(event){dragPro(event);}
</script>
</body>
</html>

위 내용은 제가 모두를 위해 정리한 내용입니다. 앞으로 모든 분들께 도움이 되길 바랍니다.

관련 기사:

프롬프트가 포함된 Ajax 확인 양식 예

Ajax를 기반으로 드롭다운 상자 연결 표시 데이터 구현

jquery의 Ajax 동기화 및 비동기에 대한 자세한 설명

위 내용은 Ajax는 새로 고침되지 않는 팝업 도시 선택 기능 코드를 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.