欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP+Mysql+jQuery查詢和列表框選擇操作實(shí)例講解

 更新時(shí)間:2015年10月22日 15:11:34   投稿:lijiao  
這篇文章主要介紹了PHP+Mysql+jQuery查詢和列表框選擇操作實(shí)現(xiàn)過(guò)程,需要的朋友可以參考下

本文講解如何通過(guò)ajax查詢mysql數(shù)據(jù),并將返回的數(shù)據(jù)顯示在待選列表中,再通過(guò)選擇最終將選項(xiàng)加入到已選區(qū),可以用在許多后臺(tái)管理系統(tǒng)中。本文列表框的操作依賴jquery插件。

HTML

<form id="sel_form" action="post.php" method="post"> 
  <p><input type="text" name="keys" id="keys" value="輸入姓名或手機(jī)號(hào)碼" onclick="this.value=''" /> 
  <input type="button" id="searchOption" value="搜索" /> <span id="msg_ser"></span></p> 
  <div id="sel"> 
  <select name="liOption[]" id='liOption' multiple='multiple' size='8'> 
  </select> 
  </div> 
  <input type="submit" value="提 交" /> 
</form> 

說(shuō)明,HTML內(nèi)容是一個(gè)表單,里面放置有一個(gè)查詢輸入框,和一個(gè)列表框,以及相關(guān)按鈕。

MYSQL數(shù)據(jù)表結(jié)構(gòu)

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是一張聯(lián)系人資料表,包括姓名和手機(jī)號(hào)碼字段。

CSS

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

本例中只加載了Multiselect插件所需的樣式文件,其他CSS大家可以自行設(shè)計(jì)。
JAVASCRIPT
首先需要引用本例所需的兩個(gè)js文件。

<script type="text/javascript" src="js/jquery.js"></script> 
<script type="text/javascript" src="js/jquery.multiselect2side.js"></script> 
<link rel="stylesheet" type="text/css" href="jquery.multiselect2side.css" /> 

接著我們來(lái)調(diào)用Multiselect插件。

$("#liOption").multiselect2side({ 
  selectedPosition: 'right', 
  moveOptions: false, 
  labelsx: '待選區(qū)', 
  labeldx: '已選區(qū)' 
}); 

然后我們來(lái)寫搜索按鈕進(jìn)行Ajax查詢數(shù)據(jù)的操作。

$("#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("沒(méi)有記錄!"); 
      }else{ 
        $("#liOptionms2side__sx").html(msg); 
        $("#msg_ser").html(""); 
      } 
     } 
  }); 
  $("#msg_ser").ajaxSend(function(event, request, settings){ 
    $(this).html(""); 
  }); 
}); 

說(shuō)明,當(dāng)點(diǎn)擊搜索按鈕時(shí),進(jìn)行的是Ajax異步操作,JAVASCRIPT將獲取的搜索框的輸入值,以POST方式傳遞給后臺(tái)程序action.php處理,處理后,返回不同的結(jié)果給JAVASCRIPT,如果返回1,HTML頁(yè)面會(huì)提示“沒(méi)有記錄”,反之,則將結(jié)果輸出給左邊列表框(待選區(qū)):liOptionms2side__sx。注意關(guān)鍵的地方到了,為什么列表框不是XHTML離的liOption,而變成了liOptionms2side__sx了呢?這個(gè)要從Multiselect插件說(shuō)起,Multiselect插件其實(shí)就是將一個(gè)列表框裝換成左右兩個(gè)列表框,已供相關(guān)操作,通過(guò)查看其插件代碼不難發(fā)現(xiàn),左邊的列表框名為:liOptionms2side__sx,右邊列表框(已選區(qū))名為:liOptionms2side__dx,后面會(huì)用到。

PHP

首先來(lái)看action.php的處理。
第一步是連接數(shù)據(jù)庫(kù)。

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

第二步讀取數(shù)據(jù),并輸出。通過(guò)檢測(cè)搜索框傳來(lái)的值,構(gòu)造不同的SQL語(yǔ)句,并將數(shù)據(jù)返回輸出,代碼如下:

$keys=trim($_POST['title']); 
$keys=mysql_real_escape_string($keys,$conn); 
if(!empty($keys)){ 
   $sql="select * from t_mult where username like '%$keys%' or phone='$keys'"; 
}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='".$row['id']."'>".$row['username']."-".$row['phone']."</option>"; 
  } 
  echo $str; 
}else{ 
  echo "1"; 
} 

最后還有一個(gè)提交操作,后臺(tái)post.php程序來(lái)獲取最終提交的項(xiàng)的值。

$selID=$_POST['liOptionms2side__dx']; 
if(!empty($selID)){ 
  $str=implode(",",$selID); 
  echo $str; 
}else{ 
  echo "沒(méi)有選擇任何項(xiàng)目!"; 
} 

注意,我們獲取的是右邊列表框liOptionms2side__dx的值,而不是liOption的值。
一個(gè)查詢、操作的例子實(shí)現(xiàn)了,但是還有一點(diǎn)點(diǎn)瑕疵,在待選區(qū)往已選區(qū)添加項(xiàng)目時(shí),如何判斷控制已經(jīng)添加過(guò)的項(xiàng)目不能重復(fù)添加,這個(gè)就留給大家思考吧,試一試有什么好的解決方式。

相關(guān)文章

  • PHP設(shè)計(jì)模式之命令模式示例詳解

    PHP設(shè)計(jì)模式之命令模式示例詳解

    這篇文章主要給大家介紹了關(guān)于PHP設(shè)計(jì)模式之命令模式的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • php empty()與isset()區(qū)別的詳細(xì)介紹

    php empty()與isset()區(qū)別的詳細(xì)介紹

    本篇文章是對(duì)php中empty()與isset()的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • 詳解Laravel框架的依賴注入功能

    詳解Laravel框架的依賴注入功能

    依賴注入不是讓對(duì)象創(chuàng)建一個(gè)依賴關(guān)系,也不是讓工廠對(duì)象去創(chuàng)建對(duì)象,而是將所需的依賴變成一個(gè)外部對(duì)象,使之成為一個(gè)"某些人的問(wèn)題”,你為"某些人的問(wèn)題”注入了類的依賴關(guān)系。在Laravel中,這個(gè)"某人”是服務(wù)容器,服務(wù)容器負(fù)責(zé)通過(guò)構(gòu)造函數(shù)注入類的依賴關(guān)系。
    2021-05-05
  • php中Workerman框架實(shí)例講解

    php中Workerman框架實(shí)例講解

    在本篇文章里小編給大家分享了一篇關(guān)于php中Workerman框架實(shí)例講解內(nèi)容,對(duì)此有興趣的朋友們可以學(xué)習(xí)參考下。
    2021-02-02
  • PHP 遍歷文件實(shí)現(xiàn)代碼

    PHP 遍歷文件實(shí)現(xiàn)代碼

    小筆記, PHP 遍歷所有文件, 包括子目錄中的文件. 和壓縮文件的類結(jié)合起來(lái)的話, 就可以打包整個(gè)目錄了.
    2011-05-05
  • PHP中l(wèi)ocaleconv()函數(shù)的用法

    PHP中l(wèi)ocaleconv()函數(shù)的用法

    今天小編就為大家分享一篇關(guān)于PHP中l(wèi)ocaleconv()函數(shù)的用法,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-03-03
  • PHP實(shí)現(xiàn)的各種進(jìn)制相互轉(zhuǎn)換功能小工具示例

    PHP實(shí)現(xiàn)的各種進(jìn)制相互轉(zhuǎn)換功能小工具示例

    這篇文章主要介紹了PHP實(shí)現(xiàn)的各種進(jìn)制相互轉(zhuǎn)換功能小工具,涉及php常見(jiàn)的二進(jìn)制、八進(jìn)制、十六進(jìn)制等相互轉(zhuǎn)換操作實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2018-03-03
  • 探討如何在PHP開(kāi)啟gzip頁(yè)面壓縮實(shí)例

    探討如何在PHP開(kāi)啟gzip頁(yè)面壓縮實(shí)例

    本篇文章是對(duì)PHP開(kāi)啟gzip頁(yè)面壓縮實(shí)例進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • PHP實(shí)現(xiàn)XML與數(shù)據(jù)格式進(jìn)行轉(zhuǎn)換類實(shí)例

    PHP實(shí)現(xiàn)XML與數(shù)據(jù)格式進(jìn)行轉(zhuǎn)換類實(shí)例

    這篇文章主要介紹了PHP實(shí)現(xiàn)XML與數(shù)據(jù)格式進(jìn)行轉(zhuǎn)換類,實(shí)例分析了php進(jìn)行XML格式數(shù)據(jù)的方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • Thinkphp結(jié)合ajaxFileUpload實(shí)現(xiàn)異步圖片傳輸示例

    Thinkphp結(jié)合ajaxFileUpload實(shí)現(xiàn)異步圖片傳輸示例

    這篇文章主要給大家介紹了利用Thinkphp結(jié)合ajaxFileUpload實(shí)現(xiàn)異步圖片傳輸?shù)姆椒?,文中給出了詳細(xì)的示例代碼,對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-03-03

最新評(píng)論