Просмотркак создать кнопку, как с помощью JQuery, Ajax и CodeIgniter
Я попытался создать кнопку, как здесь. И каждый раз, когда я нажимаю кнопку, как он увеличивается на 1. Вот как я поставил значение из базы данных, используя foreach()
петли и подачи его в JQuery
<script type="text/javascript">
$(document).ready(function(){
$("#like").click(function() {
var id='1069347886434951';//this is not artist who likes
var creation_id= 1;
$.ajax({
type: "post",
url: "<?php echo base_url(); ?>creations/like_creation",
data:'id='+id + '&creation_id=' +creation_id,//after its split, the split function gives an array
success: function(response){
try{
if(response=='true'){
var newValue = parseInt($("#like").text()) + 1;
$("#"+voteId+'_result').html(newValue);// adds the value to no of like on the client side
}else{
alert('Sorry Unable to update..');
}
}catch(e) {
alert('Exception while request..');
}
},
error: function(){
alert('Error while request..');
}
});
});
});
</script>
Контроллер Контроллер вставляет значение в базе данных. Если вы поместите значение, используя postman, он вернет true, используя json до ajax. Я пробовал это в почтальоне, и это так.
public function like_creation(){
//$artist_id=$this->session->userdata('user_id');
$artist_id=$this->input->post('id');
//bring creation id from the database when fed using foreach loop
$creation_id=$this->input->post('creation_id');
//$up_like1 =0;
$data1=array(
'id'=> $this->input->post('id'),//bring it from artist_infors
'creation_id'=> $this->input->post('creation_id'),
'artist_who_likes'=> $artist_id ,
);
$query=$this->hbmodel->insert_like($data1);
$status= "true";
echo $status;
}
Модель
public function no_likes($artist_id, $creation_id)
{
$sql="SELECT count(like_id) as num from likes as l where id='$artist_id' and creation_id= $creation_id";
//artist id has to determine whether it is user himself or the one whom he/she tries to follow
$query=$this->db->query($sql);
return $query->result();
}
MySQL Query
CREATE TABLE IF NOT EXISTS `likes` (
`like_id` int(11) NOT NULL AUTO_INCREMENT,
`id` varchar(500) COLLATE utf16_bin DEFAULT NULL,//the artist id whose creation is fed
`creation_id` int(11) DEFAULT NULL,
`artist_who_likes` varchar(500) COLLATE utf16_bin DEFAULT NULL,
PRIMARY KEY (`like_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf16 COLLATE=utf16_bin AUTO_INCREMENT=29 ;
В чем вопрос? – mplungjan
Я не могу создать, как кнопка, используя приведенный выше код. вы можете найти что-то не так с этим –
Сообщения об ошибках? Консольные сообщения? Также, что делает попытка поймать? нет кода, который генерирует исключение в вашем успехе. Вам нужно вернуть счетчик, а не true или false – mplungjan