У меня есть выпадающий список, в котором перечислены логотипы, такие как цветок, бабочка и т. Д.
<p class="title1">Logo</p>
<select name="logoMenu" class="select" size="7">
<?php foreach($logos as $logo):?>
<option id="<?php echo $logo['Subproperty']['id'];?>" value="<?php echo $logo['Subproperty']['values'];?>">
<?php echo $logo['Subproperty']['values'];?>
</option>
<?php endforeach;?>
</select>
Предположим, я выбираю логотип 'Flower' из выпадающего списка, я хочу, чтобы изображение цветка отображалось в div. Это div, который я должен отобразить картинки:
<div id="theme_logos" class="float_left spaceleft" style="display:none;">
<?php foreach($defaultLogos as $logo):
//if($logo['Subproperty']['values']==clicked option value){?>
<img height="50" width="50" src="/FormBuilder/app/webroot/img/themes/<?php echo $logo['Subproperty']['images'];?>" class="float_left user_profile_image user_profile_image" alt="Default50"/>
<?php endforeach;?>
</div>
Проблема с этим кодом состоит в том, что он отображает все изображения, найденные в таблице. Потому что в коде моего контроллера я даю только идентификатор свойства как у «Логотипа», но не указываю, какой логотип.
$this->set('defaultLogos',$this->Subproperty->find('all',array('conditions'=>array('Subproperty.property_id'=>1,'Subproperty.values'=>"Flower"))));
Здесь у меня есть жестко закодированный «цветок», так что я получаю только изображение цветка.
Если я выберу логотип из выпадающего списка, как я могу передать это выбранное значение в код контроллера? Или, если я получу название выбранного логотипа с помощью jQuery, как я могу использовать это значение в условии if внутри цикла foreach?
Я использую CakePHP
framework.
$("#logoMenu option").click(function(){
selectedLogo=$(this).attr("value");
$('#subproperty_id').val($(this).attr("id"));
if(selectedLogo=="Your logo"){
$("#themes_upload").show();
}
else{
alert(selectedLogo);
$("#themes_upload").hide();
$("#theme_logos").show();
}
});
EDIT:
Теперь я попробовал AJAX POST, где я передаю выбранный логотип тому же действию контроллера. Я получаю значение, когда оповещаю о переданном значении в функции успеха функции ajax, но картинка не появляется.
$("#logoMenu option").click(function(){
selectedLogo=$(this).attr("value");
$('#subproperty_id').val($(this).attr("id"));
if(selectedLogo=="Your logo"){
$("#themes_upload").show();
} else {
alert(selectedLogo);
$.ajax({
type: "POST",
url: "http://localhost/FormBuilder/index.php/themes/themes/",
async: false,
data: "selectedLogo="+selectedLogo,
success: function(msg){
alert( "Data Saved: " + msg);
}
});
$("#themes_upload").hide();
$("#theme_logos").show();
}
function themes(){
$this->set('themes',$this->Theme->find('all'));
$logo=$this->params['form']['selectedLogo'];
echo "logo:".$logo;
$this->set('defaultLogos',$this->Subproperty->find('all',array('conditions'=>array('Subproperty.property_id'=>1,'Subproperty.values'=>$logo))));
}
Когда я пытаюсь отобразить изображение на странице, оно не появляется. Это потому, что команда div show находится после запроса AJAX?