千家信息网

如何使用$.get()根据选项的不同从数据库异步请求数据

发表于:2025-01-17 作者:千家信息网编辑
千家信息网最后更新 2025年01月17日,这篇文章给大家介绍如何使用$.get()根据选项的不同从数据库异步请求数据,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Ajax极大地改善了用户体验,对于web2.0来说必不可少
千家信息网最后更新 2025年01月17日如何使用$.get()根据选项的不同从数据库异步请求数据

这篇文章给大家介绍如何使用$.get()根据选项的不同从数据库异步请求数据,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

Ajax极大地改善了用户体验,对于web2.0来说必不可少,是前端开发人员必不可少的技能。
这个例子是这样的,当从select下拉框选择编程语言时时,根据选项的不同,异步请求不同的函数API描述。这种功能在现在web应用程序中是及其常见的。
我们先来看一下$.get()的结构

代码如下:

$.get(url, [, data], [, callback] [, type]) //url:请求的HTML页的URL地址; //data(可选),发送至服务器的key/value数据作为QueryString附加到请求URL中; //callback(可选):载入成功时的回调函数(只有当Response的返回状态是success才调用该方法; //type(可选):服务器端返回内容格式,包括xml,html,script,json,text和_default


首先创建examplDB数据库,建立language和functions表,SQL如下

代码如下:

CREATE TABLE IF NOT EXISTS language ( id int(3) NOT NULL AUTO_INCREMENT, languageName varchar(50) NOT NULL, PRIMARY KEY (id)); CREATE TABLE IF NOT EXISTS functions ( id int(3) NOT NULL AUTO_INCREMENT, languageId int(11) NOT NULL, functionName varchar(64) NOT NULL, summary varchar(128) NOT NULL, //功能概述 example text NOT NULL, //举例 PRIMARY KEY (id));


下面是插入数据的SQL

代码如下:

INSERT INTO language (id, languageName) VALUES (1, 'PHP'), (2, 'jQuery'); INSERT INTO functions (id, languageId, functionName, summary, example) VALUES (1, 1, 'simplexml_load_file', 'Interprets an XML file into an object ', '$xml = simplexml_load_file(''test.xml'');\r\nprint_r($xml);\r\n'), (2, 1, 'array_push', 'Push one or more elements onto the end of array', '$arrPets = array(''Dog'', ''Cat'', ''Fish'' );\r\narray_push($arrPets, ''Bird'', ''Rat'');\r\n'), (3, 1, 'ucfirst', 'Make a string''s first character uppercase', '$message = ''have a nice day;\r\n$message = ucfirst($message); // output: Have A Nice Day\r\n'), (4, 1, 'mail', 'used to send email', '$message = "Example message for mail";\r\nif(mail(''test@test.com'', ''Test Subject'', $message))\r\n{\r\n echo ''Mail sent'';\r\n}\r\nelse\r\n{\r\n echo ''Sending of mail failed'';\r\n}\r\n'), (5, 2, '$.get', 'Load data from the server using a HTTP GET request.', '$.ajax({\r\n url: url,\r\n data: data,\r\n success: success,\r\n dataType: dataType\r\n});\r\n'), (6, 2, 'hover', 'hover method accepts 2 functions as parameters which execute alternativelt when mouse enters and leaves an element.', '$(selector).hover(\r\nfunction()\r\n{\r\n//executes on mouseenter\r\n},\r\nfunction()\r\n{\r\n//executes on mouseleave\r\n});'), (7, 2, 'bind', 'Attach a handler to an event for the elements.', '$(element).bind(''click'', function() \r\n{\r\n alert(''click happened'');\r\n});\r\n'), (8, 2, 'jQuery.data', 'Store arbitrary data associated with the specified element.', 'jQuery.data(element, key, value);'), (9, 1, 'add class', 'Adds a class', '(''p'').addClass(''myClass yourClass'');');

都是比较简单的SQL操作,一切准备就绪后就可以编码了。总共有两个脚本文件,一个index.php,一个results.php用于处理请求,先编写index.php

代码如下:

        query($query)) { if ($result->num_rows > 0) { ?> 

Select a languae

close(); } else { echo 'Error in query: $query.'.$mysqli->error; } } $mysqli->close(); ?>


引入jquery,给#selectLanguage添加change事件处理程序,并放在index.php中body结束前

代码如下:

 


下面就是results.php了。它先连接到数据库,然后取得index.php发送到id,根据id在数据库里选择相应的编程语言记录,并将每条记录放到ul列表中

复制代码 代码如下:

query($query)) { if ($result->num_rows > 0) { $resultStr .= '
    '; while($row = $result->fetch_assoc()) //和index.php的语句差不多,也是先从数据库取得记录,然后格式化输出 { $resultStr .= '
  • '.$row['functionName'].'-'.$row['summary']; $resultStr .= '
    '.$row['example'].'
    '.'
  • '; } $resultStr .= '
'; } else { $resultStr = 'Nothing found'; } } echo $resultStr; ?>


现在所有的代码都编写好了,看下最后的效果

这样简单的效果就出来了。

关于如何使用$.get()根据选项的不同从数据库异步请求数据就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

0