>  기사  >  백엔드 개발  >  (고급) PHP+Mysql+jQuery는 쿼리 및 목록 상자 선택 작업을 구현합니다.

(고급) PHP+Mysql+jQuery는 쿼리 및 목록 상자 선택 작업을 구현합니다.

黄舟
黄舟원래의
2017-02-07 09:30:161478검색

이 글에서는 ajax를 통해 mysql 데이터를 쿼리하고, 반환된 데이터를 선택 목록에 표시한 후 마지막으로 선택을 통해 선택한 선택 항목에 옵션을 추가하는 방법을 설명합니다. 이 기사의 목록 상자 작업은 jquery 플러그인인 Multiselect를 사용합니다.

(고급) PHP+Mysql+jQuery는 쿼리 및 목록 상자 선택 작업을 구현합니다.

<form id="sel_form" action="post.php" method="post"> 
   <p><input type="text" name="keys" id="keys" value="输入姓名或手机号码" onclick="this.value=&#39;&#39;" /> 
    <input type="button" id="searchOption" value="搜索" /> <span id="msg_ser"></span></p> 
   <div id="sel"> 
   <select name="liOption[]" id=&#39;liOption&#39; multiple=&#39;multiple&#39; size=&#39;8&#39;> 
   </select> 
   </div> 
   <input type="submit" value="提 交" /> 
</form>

HTML 콘텐츠는 쿼리 입력 상자, 목록 상자 및 관련 버튼이 포함된 형식임을 설명합니다.

MYSQL 데이터 테이블 구조

CREATE TABLE IF NOT EXISTS `t_mult` ( 
  `id` int(11) NOT NULL auto_increment, 
  `username` varchar(32) NOT NULL, 
  `phone` varchar(20) NOT NULL, 
  PRIMARY KEY  (`id`) 
) ENGINE=MyISAM  DEFAULT CHARSET=utf8;

테이블 t_mult는 이름과 휴대폰 번호 필드를 포함하는 연락처 정보 테이블입니다.

<link rel="stylesheet" type="text/css" href="jquery.multiselect2side.css" />

이 예에서는 Multiselect 플러그인에 필요한 스타일 파일만 로드됩니다. 다른 CSS를 직접 디자인할 수도 있습니다.

먼저 이 예에 필요한 두 개의 js 파일을 참조해야 합니다.

 
 
<link rel="stylesheet" type="text/css" href="jquery.multiselect2side.css" />

그럼 Multiselect 플러그인을 호출해 보겠습니다.

$("#liOption").multiselect2side({ 
    selectedPosition: &#39;right&#39;, 
    moveOptions: false, 
    labelsx: &#39;待选区&#39;, 
    labeldx: &#39;已选区&#39; 
});

그럼 Ajax 쿼리 데이터를 수행하는 검색 버튼을 작성해 보겠습니다.

$("#searchOption").click(function(){ 
    var keys=$("#keys").val(); 
    $.ajax({ 
         type: "POST", 
         url: "action.php", 
         data: "title="+keys, 
         success: function(msg){ 
            if(msg==1){ 
                $("#msg_ser").show().html("没有记录!"); 
            }else{ 
                $("#liOptionms2side__sx").html(msg); 
                $("#msg_ser").html(""); 
            } 
         } 
    }); 
    $("#msg_ser").ajaxSend(function(event, request, settings){ 
        $(this).html(""); 
    }); 
});

검색 버튼을 클릭하면 Ajax 비동기 작업이 수행되며 JAVASCRIPT는 처리 후 POST 모드에서 검색 상자의 입력 값을 백그라운드 프로그램 action.php에 전달합니다. 다른 값이 반환됩니다. 결과는 JAVASCRIPT에 제공됩니다. 1이 반환되면 HTML 페이지에 "기록 없음" 메시지가 표시됩니다. 그렇지 않으면 결과가 왼쪽 목록 상자(선택됨)에 출력됩니다. 여기서 중요한 점은 목록 상자가 XHTML의 liOption이 아니라 liOptionms2side__sx인 이유는 무엇입니까? 이는 Multiselect 플러그인으로 시작됩니다. Multiselect 플러그인은 실제로 관련 작업을 위해 목록 상자를 두 개의 왼쪽 및 오른쪽 목록 상자로 대체합니다. 플러그인 코드를 보면 찾기가 어렵지 않습니다. 왼쪽의 이름은 liOptionms2side__sx이고 오른쪽의 목록은 (선택된) 상자의 이름은 liOptionms2side__dx이며 나중에 사용됩니다.

PHP

먼저 action.php 처리 과정을 살펴보겠습니다.

첫 번째 단계는 데이터베이스에 연결하는 것입니다.

$conn=mysql_connect("localhost","root",""); 
mysql_select_db("demo",$conn); 
mysql_query("SET names UTF8");

두 번째 단계는 데이터를 읽고 출력하는 것입니다. 검색 상자에서 전달된 값을 감지하여 다양한 SQL 문을 구성하고 데이터를 출력에 반환합니다. 코드는 다음과 같습니다.

$keys=trim($_POST[&#39;title&#39;]); 
$keys=mysql_real_escape_string($keys,$conn); 
if(!empty($keys)){ 
        $sql="select * from t_mult where username like &#39;%$keys%&#39; or phone=&#39;$keys&#39;"; 
}else{ 
        $sql="select * from t_mult"; 
} 
$query=mysql_query($sql); 
$count=mysql_num_rows($query); 
if($count>0){ 
      while($row=mysql_fetch_array($query)){ 
          $str.="<option value=&#39;".$row[&#39;id&#39;]."&#39;>".$row[&#39;username&#39;]."-".$row[&#39;phone&#39;]."</option>"; 
    } 
    echo $str; 
}else{ 
      echo "1"; 
}

마지막으로 제출 작업과 배경 post.php가 있습니다. 프로그램은 최종 제출된 항목 값을 얻는 데 사용됩니다.

$selID=$_POST[&#39;liOptionms2side__dx&#39;]; 
if(!empty($selID)){ 
    $str=implode(",",$selID); 
    echo $str; 
}else{ 
    echo "没有选择任何项目!"; 
}

우리가 얻는 것은 liOption의 값이 아니라 오른쪽 목록 상자에 있는 liOptionms2side__dx의 값입니다.

위 내용은 쿼리 및 목록 상자 선택 작업을 구현하는 (고급 기사) PHP+Mysql+jQuery의 내용이며, 더 많은 관련 내용은 PHP 중국어 사이트(www.php.cn)를 참고하시기 바랍니다. !


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