我想使用select
元素来移动查看我的网站。以下是select
选项。
HTML:
<select name="select-choice-8" id="select-choice-nc">
<optgroup label="News">
<option value="feature">Fea</option>
<option value="current">Current</option>
<option value="research">Research</option>
</optgroup>
<optgroup label="Archive">
<option value="archive">Archive</option>
</optgroup>
<optgroup label="Video">
<option value="">Video</option>
</optgroup>
<optgroup label="Submit">
<option value="">Story</option>
<option value="">Event</option>
</optgroup>
</select>
我希望使用JavaScript / jQuery根据用户选择的内容进行一些AJAX调用,以避免重新加载整个页面(例如,使用返回的AJAX内容填充容器)。
我需要一些想法或例子来解决这个问题。
提前致谢。
答案 0 :(得分:0)
我对jQuery并不熟悉,但你能够找到正确的语法。 我们的想法是根据您选择的选项获取适当的HTML。也就是说,它的对应值。
考虑testHTML:
<div id="News"></div>
<div id="Archive"></div>
<div id="Video"></div>
和JavaScript:
$.each("option").click(function() {
var label = $(this).parent.label;
var elementToUpdate = $( "#" + label ); // one of the divs in TestHTML
var value = (this).value;
var url = "http://mysite.php?id=" + value;
var newHTML = $.ajax({ url: url }).done(function(){
elementToUpdate.replaceWith( newHTML );
});
});
或者甚至可能:
<div id="selectedContent"></div>
和
$.each("option").click(function() {
var elementToUpdate = $( "#selectedContent" ); // one of the divs in TestHTML
var value = (this).value;
var url = "http://mysite.php?id=" + value;
var newHTML = $.ajax({ url: url }).done(function(){
elementToUpdate.replaceWith( newHTML );
});
});
答案 1 :(得分:0)
试试这个:http://shaquin.tk/experiments/select-ajax2.html。
<强> HTML:强>
<select name="select-choice" id="select-choice">
<optgroup label="News">
<option value="feature">Feature</option>
<option value="current">Current</option>
<option value="research">Research</option>
</optgroup>
<optgroup label="Archive">
<option value="archive">Archive</option>
</optgroup>
<optgroup label="Video">
<option value="video">Video</option>
</optgroup>
<optgroup label="Submit">
<option value="story">Story</option>
<option value="event">Event</option>
</optgroup>
</select>
<div id="article">Please select an article to view.</div>
<强> JS:强>
var origText = '';
$(document).ready(function() {
origText = $('#article').text();
$('select').on('change', changed);
});
function changed(e) {
$('#article').html('<span class="loading">Loading...</span>');
$('#article').load('content.php', $.param({0: e.target.value, 1: origText}));
}
<强> PHP:强>
<?php
$selected = $_GET[0];
$articles = array(
'' => $_GET[1],
'feature' => 'Feature article goes here',
'current' => '<p>Lorem ipsum dolor sit amet, denique laetare ... se est Apollonius.</p>',
'research' => 'You selected <code>research</code>',
'archive' => 'Archives',
'video' => '<div style="font-size:48pt;font-weight:bold;font-style:italic;background:red;text-align:center;padding:20px;margin:10px;border-radius:20px;-moz-border-radius:20px;-webkit-border-radius:20px;">Video</div>',
'story' => 'Submit a story',
'event' => 'Submit an event'
);
$article = $articles[$selected];
echo $article;
?>
CSS(可选):
body {
background: #ccc;
text-align: center
}
#article {
padding: 30px;
margin: 20px;
text-align: left;
background: #eee;
text-shadow: 1px 1px #fff;
text-shadow: 0 0 3px #fff;
border-radius: 8px;
-moz-border-radius: 8px;
-webkit-border-radius: 8px;
}
.loading {
text-transform: uppercase;
font-size: 15pt;
text-shadow: 1px 1px #f00, 1px 2px #f00, 2px 2px #f00, 3px 3px #f00;
}
在PHP中,您可能希望从数据库中获取文本:PHP - MySQLi。