[ Поиск ] - [ Пользователи ] - [ Календарь ]
Полная Версия: Система голосования по принципу (+/-)
Vantedur
не могу понять что сюда вписать
<script type="text/javascript">
function getData(URL){

}

</script>


сами кнопки представляют из себя

<div class="blogpostsminus"><a href="vote.php?id=13&type=post&action=novost" onclick="getData(this.href); return false;">-</a></div>
<div
class="blogpostsplus"><a href="vote.php?id=13&type=novost&action=plus" onclick="getData(this.href); return false;">+</a></div>

это для голосания за посты
<div class="blogcommentminus"><a href="vote.php?id=13&type=comment&action=minus" onclick="getData(this.href); return false;">-</a></div>
<div
class="blogcommentsplus"><a href="vote.php?id=13&type=comment&action=plus" onclick="getData(this.href); return false;">+</a></div>



пытаюсь получить вот эти параметры в vote.php
id= номер поста или комментария
type= голосуют за пост или за комент
action= плюсанули или минусанули

вот здесь можно посмотреть как это будет выглядеть внешне http://jquery.vtrigazety.ru/&novost=1



Спустя 3 часа, 48 минут, 23 секунды (13.07.2010 - 09:59) Mirexzpalich написал(а):
Ajax вам в помощь smile.gif


Спустя 14 часов, 32 минуты, 34 секунды (14.07.2010 - 00:32) Vantedur написал(а):
нарыл отличную голосовалку однако она столь огромная что не понятно как её с php завязать.
http://vtrigazety.ru/lepra.png принт скрин

function initVoting(type, parentElementId){
var voteBlocks = getElementsByClassName($(parentElementId), 'div', 'vote');
if(voteBlocks.length == 0) return;

switch (type){
 case "posts":
  VoteBlock.type = VoteBlock.typePost;
  VoteBlock.theChoiceElement = $('vote_choice');
  VoteBlock.initChoiceElements();
  for (var i=0; i<voteBlocks.length; i++){
   new VoteBlock(voteBlocks[i]);
  }  
  break;
 case "comments":
  VoteBlock.type = VoteBlock.typeComment;
  for (var i=0; i<voteBlocks.length; i++){
   new VoteBlockComments(voteBlocks[i]);
   //initShrink(voteBlocks[i].parentNode);
  }  
  break;
 case "lepraposts":
  VoteBlock.type = VoteBlock.typePost;
  for (var i=0; i<voteBlocks.length; i++){
   new VoteBlockComments(voteBlocks[i]);
  }
  break;
 default:
  break;
}
}



function initShrink(parent){
if(getElementsByClassName(parent, 'a', 'show_link').length == 0) return;

var showLink = getElementsByClassName(parent, 'a', 'show_link')[0];
showLink.onclick = function (){
 removeClass(this.parentNode.parentNode.parentNode, 'shrinked');
 return false;
}
}



/* Класс VoteBlock (для голосования с плюсом и лопатой)
***************************************************************/

function VoteBlock(htmlObj){
this.htmlObj = htmlObj; // контейнер, содержащий все элементы голосования
if (getElementsByClassName(this.htmlObj, 'a', 'plus').length == 0){
 return;
}
this.htmlObjChildren = this.htmlObj.getElementsByTagName('*');

this.htmlGlobalParent = htmlObj.parentNode.parentNode;  // родительский контейнер всего поста
//this.htmlGlobalParent = htmlObj.parentNode;  // родительский контейнер

this.plusBtn = getElementsByClassName(this.htmlObj, 'a', 'plus')[0];  // контейнер с кнопкой +
this.minusBtn = getElementsByClassName(this.htmlObj, 'a', 'minus')[0]; // контейнер с кнопкой -
this.rating = getElementsByClassName(this.htmlObj, 'span', 'rating')[0].firstChild; // контейнер с рейтингом


this.htmlObj.obj = this;
this.plusBtn.obj = this;
this.minusBtn.obj = this;
this.rating.obj = this;

this.voteType = VoteBlock.type;

this.initChoiceEvents();

}

// Статическое свойство VoteBlock.theChoiceElement
VoteBlock.theChoiceElement = {}; // html контейнер с элементами выбора, перемещаемый по дереву документа (всегда имеет родителем this.htmlGlobalParent)
VoteBlock.theChoiceElement.elements = []; // массив всех элементов списка VoteBlock.theChoiceElement
VoteBlock.theChoiceElement.currentObj = {}; // ссылка на объект класса VoteBlock, внутри которого сейчас находится VoteBlock.theChoiceElement
VoteBlock.urlVoting = "/rate/?"; // url при голосовании + -
VoteBlock.type = "";
VoteBlock.typeComment = 0;  // для указания, что голосуем по комментам
VoteBlock.typePost = 1; // для указания, что голосуем по постам
VoteBlock.wtf = ""; //

// Статический метод, инициализирующий объект VoteBlock.theChoiceElement и все его элементы

VoteBlock.initChoiceElements = function(){
VoteBlock.theChoiceElement.elements = VoteBlock.theChoiceElement.getElementsByTagName('a');
for (var i=0; i<VoteBlock.theChoiceElement.elements.length; i++){
 VoteBlock.theChoiceElement.elements[i].onclick = function(){
  if(matchClass(this, 'voted')){
   return false;
  } else {
   var currentObj = VoteBlock.theChoiceElement.currentObj;
   var postId = currentObj.htmlGlobalParent.getAttribute('id').substring(1);
   var choiceValue = this.getAttribute('choiceValue');
   var url = VoteBlock.urlVoting + "wtf=" + VoteBlock.wtf + "&type=" + this.obj.voteType + "&id=" + postId + "&value=" + choiceValue;

   currentObj.setChoiceVoted(choiceValue); // отрисовываем выбранный элемент
   addClass(currentObj.htmlGlobalParent, 'loading'); // ставим прелоадер
   ajaxLoad(url, currentObj.onLoad, currentObj); // отправляем/получаем данные
   return false;
  }
 }
}
}


VoteBlock.prototype.initChoiceEvents = function (){
this.htmlObj.onmouseout = function(e){
 if(!e) e = window.event;
 this.obj.hideChoice(e);
}

// Кнопка +
this.plusBtn.onmouseover = function(e){
 if(!e) e = window.event;
 this.obj.hideChoice(e, this);
}

this.plusBtn.onclick = function(){
 this.blur();
 if(matchClass(this, 'voted')){
  return false;
 } else {
  var postId = this.obj.htmlGlobalParent.getAttribute('id').substring(1);
  var choiceValue = 1;
  var url = VoteBlock.urlVoting + "wtf=" + VoteBlock.wtf + "&type=" + this.obj.voteType + "&id=" + postId + "&value=" + choiceValue;

  this.obj.setChoiceVoted(null);
  addClass(this, 'voted'); // отмечаем сделанный выбор
  addClass(this.obj.htmlGlobalParent, 'loading'); // ставим прелоадер
  ajaxLoad(url, this.obj.onLoad, this.obj); // отправляем/получаем данные
  return false;
 }
}


// Кнопка -
this.minusBtn.onmouseover = function(){
 this.obj.showChoice();

 // отвратительный хак против IE6- (заставляет не скакать правую колонку)
 if(typeof document.body.style.maxWidth == 'undefined' && $('content_right_inner')){
  $('content_right_inner').style.display = "none";
  $('content_right_inner').style.display = "block";
 }
}


this.minusBtn.onclick = function(){
 this.blur();
 return false;
}
}


// Отрисовка блока VoteBlock.theChoiceElement
VoteBlock.prototype.showChoice = function(){
if (typeof VoteBlock.theChoiceElement == 'undefined') return;

VoteBlock.theChoiceElement.currentObj = this; // создаем ссылку на новый родительский объект у VoteBlock.theChoiceElement
addClass(VoteBlock.theChoiceElement.currentObj.htmlGlobalParent, 'inuse'); // располагаем htmlGlobalParent поверх отсальных

this.showChoiceVoted(); // отрисовываем текущий голосованный элемент

this.htmlObj.appendChild(VoteBlock.theChoiceElement);
VoteBlock.theChoiceElement.style.display = 'block';
}

VoteBlock.prototype.hideChoice = function(e, obj){
if (typeof VoteBlock.theChoiceElement == 'undefined') return;

// если mouseover на кнопке "плюс", скрываем чойс бокс
if(obj && matchClass(obj, "plus")){
 addClass(this.htmlGlobalParent, 'inuse'); // располагаем htmlGlobalParent поверх отсальных
 VoteBlock.theChoiceElement.style.display = 'none';
 return;
}

// если элемент, на который передвигаем мышь, лежит внутри чойс блока, выходим
if (e.relatedTarget) {
 var where = e.relatedTarget;
 if (where == this.htmlObj) return;
 if (where.nodeType == 3) where = where.parentNode;
 for(var i=0; i<this.htmlObjChildren.length; i++){
  if (where == this.htmlObjChildren[i]) {
   return;
  }
 }
}
else if (e.toElement && this.htmlObj.contains(e.toElement)) {
 return;
}

removeClass(this.htmlGlobalParent, 'inuse'); // снимаем свойство с htmlGlobalParent лежать поверх отсальных
VoteBlock.theChoiceElement.style.display = 'none';
}

// Отрисовка пункта, за который проголосовали, в списке элементов VoteBlock.theChoiceElement
VoteBlock.prototype.showChoiceVoted = function (){
var currentChoiceValue = this.minusBtn.getAttribute('choiceValue');
for (var i=0; i<VoteBlock.theChoiceElement.elements.length; i++){
 var currentElement = VoteBlock.theChoiceElement.elements[i];
 if (currentElement.getAttribute('choiceValue') == currentChoiceValue){
  addClass(currentElement, 'voted');
 } else {
  removeClass(currentElement, 'voted');
 }
}
}


// Установка нового выбранного значения в списке элементов VoteBlock.theChoiceElement
VoteBlock.prototype.setChoiceVoted = function(choiceMinusValue){
this.minusBtn.setAttribute('choiceValue', choiceMinusValue);
if(matchClass(this.plusBtn, 'voted')) {
 removeClass(this.plusBtn, 'voted');
}
this.showChoiceVoted();
}

VoteBlock.prototype.onLoad = function (ajaxObj){
var newRating = ajaxObj.responseText;
this.rating.innerHTML = newRating;
removeClass(this.htmlGlobalParent, 'loading'); // убираем прелоадер
}




/* Подкласс VoteBlockComments (для голосования с плюсом и минусом)
*************************************************************************/

function VoteBlockComments (htmlObj){
VoteBlockComments.baseConstructor.call(this, htmlObj);
}
VoteBlockComments.inheritFrom(VoteBlock);

VoteBlockComments.prototype.initChoiceEvents = function (){

this.htmlObj.onmouseout = function(e){
 if(!e) e = window.event;
 this.obj.hideChoice(e);
}

// Кнопка +
this.plusBtn.onmouseover = function(e){
 return false;
}

this.plusBtn.onclick = function(){
 this.blur();
 if(matchClass(this, 'voted')){
  return false;
 } else {
  var postId = this.obj.htmlGlobalParent.getAttribute('id');
  var choiceValue = 1;
  var url = VoteBlock.urlVoting + "wtf=" + VoteBlock.wtf + "&type=" + this.obj.voteType + "&id=" + postId + "&value=" + choiceValue;

  addClass(this, 'voted'); // отмечаем сделанный выбор
  removeClass(this.obj.minusBtn, 'voted') // снимаем отметку о противоположном голосовании
  addClass(this.obj.htmlGlobalParent, 'loading'); // ставим прелоадер

  ajaxLoad(url, this.obj.onLoad, this.obj); // отправляем/получаем данные

  return false;
 }
}


// Кнопка -
this.minusBtn.onmouseover = function(){
 return false;
}

this.minusBtn.onclick = function(){
 this.blur();
 if(matchClass(this, 'voted')){
  return false;
 } else {
  var postId = this.obj.htmlGlobalParent.getAttribute('id');
  var choiceValue = -1;
  var url = VoteBlock.urlVoting + "wtf=" + VoteBlock.wtf + "&type=" + this.obj.voteType + "&id=" + postId + "&value=" + choiceValue;

  addClass(this, 'voted'); // отмечаем сделанный выбор
  removeClass(this.obj.plusBtn, 'voted') // снимаем отметку о противоположном голосовании
  addClass(this.obj.htmlGlobalParent, 'loading'); // ставим прелоадер
  addClass(this.obj.htmlGlobalParent, 'shrinked');

  ajaxLoad(url, this.obj.onLoad, this.obj); // отправляем/получаем данные
  return false;
 }
 return false;
}

this.rating.onmouseover = function(){
 this.obj.showChoice();
}
}


VoteBlockComments.prototype.showChoice = function(){
addClass(this.htmlGlobalParent, 'inuse');
}

VoteBlockComments.prototype.hideChoice = function(e, obj){

// если элемент, на который передвигаем мышь, лежит внутри чойс блока, выходим
if (e.relatedTarget) {
 var where = e.relatedTarget;
 if (where == this.htmlObj) return;
 if (where.nodeType == 3) where = where.parentNode;
 for(var i=0; i<this.htmlObjChildren.length; i++){
  if (where == this.htmlObjChildren[i]) {
   return;
  }
 }
 //e.relatedTarget.style.border = "none"; // странно, но это побороло баг в Opere :/
} else if (e.toElement && this.htmlObj.contains(e.toElement)) {
 return;
}

removeClass(this.htmlGlobalParent, 'inuse');
}



/* Класс VoteBlockUser (для голосования с 2 плюсами и 2 минусами по юзеру)
*************************************************************************/

function initVotingUser (parentObjId){
var parentObj = $(parentObjId);
var voteBlocks = parentObj.getElementsByTagName('strong');
if(voteBlocks.length == 0) return;

var ratingBlock = getElementsByClassName(parentObj, 'span', 'rating')[0].firstChild; // контейнер с рейтингом

for (var i=0; i<voteBlocks.length; i++){
 new VoteBlockUser(voteBlocks[i], ratingBlock);
}
}



function VoteBlockUser(htmlObj, ratingBlock){
this.htmlObj = htmlObj;

this.htmlGlobalParent = htmlObj.parentNode.parentNode;  // родительский контейнер всего поста
this.plusBtn = getElementsByClassName(this.htmlObj, 'a', 'plus')[0];  // контейнер с кнопкой +
this.minusBtn = getElementsByClassName(this.htmlObj, 'a', 'minus')[0]; // контейнер с кнопкой -
this.rating = ratingBlock;

this.htmlObj.obj = this;
this.plusBtn.obj = this;
this.minusBtn.obj = this;
this.rating.obj = this;

this.initChoiceEvents();
}

VoteBlockUser.urlVoting = "/karma/"; // url при голосовании + -
VoteBlockUser.wtf = ""; //

VoteBlockUser.prototype.initChoiceEvents = function (){
this.plusBtn.onclick = function(){
 this.blur();
 if(matchClass(this, 'voted')){
  return false;
 } else {
  var userId = this.obj.htmlGlobalParent.getAttribute('uid');
  var choiceValue = this.getAttribute('choiceValue');
  var url = VoteBlockUser.urlVoting;
  var data = "wtf=" + VoteBlockUser.wtf + "&u_id=" + userId + "&value=" + choiceValue;

  addClass(this, 'voted'); // отмечаем сделанный выбор
  removeClass(this.obj.minusBtn, 'voted') // снимаем отметку о противоположном голосовании
  addClass(this.obj.htmlGlobalParent, 'loading'); // ставим прелоадер

  ajaxLoadPost(url, data, this.obj.onLoad, this.obj); // отправляем/получаем данные
  return false;
 }
}


this.minusBtn.onclick = function(){
 this.blur();
 if(matchClass(this, 'voted')){
  return false;
 } else {
  var userId = this.obj.htmlGlobalParent.getAttribute('uid');
  var choiceValue = this.getAttribute('choiceValue');
  var url = VoteBlockUser.urlVoting;
  var data = "wtf=" + VoteBlockUser.wtf + "&u_id=" + userId + "&value=" + choiceValue;
 
  addClass(this, 'voted'); // отмечаем сделанный выбор
  removeClass(this.obj.plusBtn, 'voted') // снимаем отметку о противоположном голосовании
  addClass(this.obj.htmlGlobalParent, 'loading'); // ставим прелоадер

  ajaxLoadPost(url, data, this.obj.onLoad, this.obj); // отправляем/получаем данные
  return false;
 }
 return false;
}

}


VoteBlockUser.prototype.onLoad = function (ajaxObj){
var newRating = ajaxObj.responseText;
this.rating.innerHTML = newRating;
removeClass(this.htmlGlobalParent, 'loading'); // убираем прелоадер
}



/* Альтернативные функции */
var wtf_vote = null;

function vote (linkBtn, post_id){
linkBtn.blur();
if(matchClass(linkBtn, 'voted')) return false;

var linkGlobalParent = linkBtn.parentNode.parentNode.parentNode.parentNode;
var id = linkGlobalParent.id;
var linkParent = linkBtn.parentNode;
var rating = getElementsByClassName(linkParent, 'span', 'rating')[0].firstChild; // контейнер с рейтингом
var value;
var oppositeBtn;
var showLink = getElementsByClassName(linkGlobalParent, 'a', 'show_link')[0];

if (matchClass(linkBtn, 'plus')){
 value = 1;
 oppositeBtn = getElementsByClassName(linkParent, 'a', 'minus')[0];  
} else {
 value = -1;
 oppositeBtn = getElementsByClassName(linkParent, 'a', 'plus')[0];

 if(typeof noShrink != 'undefined'){
  noShrink(showLink);
 }
 //addClass(linkGlobalParent, 'shrinked');  
}

addClass(linkBtn, 'voted'); // отмечаем сделанный выбор
removeClass(oppositeBtn, 'voted') // снимаем отметку о противоположном голосовании
addClass(linkGlobalParent, 'loading'); // ставим прелоадер

var url = "/rate/";
var data = "type=0&wtf=" + wtf_vote + "&id=" + id + "&value=" + value + "&post_id=" + post_id;
var params = {r:rating, gp:linkGlobalParent};

ajaxLoadPost(url, data, voteonLoad, window, params, votePostonError); // отправляем/получаем данные
return false;
}

function voteonLoad(ajaxObj, params){
var rating = params.r;
var linkGlobalParent = params.gp;
var newRating = ajaxObj.responseText;

rating.innerHTML = newRating;
removeClass(linkGlobalParent, 'loading'); // убираем прелоадер
}

function showChoice(link){
var linkGlobalParent = link.parentNode.parentNode.parentNode.parentNode;
addClass(linkGlobalParent, 'inuse');
}

function hideChoice(e, obj){
var objChildren = obj.getElementsByTagName('*');
var objGlobalParent = obj.parentNode.parentNode;

// если элемент, на который передвигаем мышь, лежит внутри чойс блока, выходим
if (e.relatedTarget) {
 var where = e.relatedTarget;
 if (where == obj) return;
 if (where.nodeType == 3) where = where.parentNode;
 for(var i=0; i<objChildren.length; i++){
  if (where == objChildren[i]) {
   return;
  }
 }

 //e.relatedTarget.style.border = "none"; // странно, но это побороло баг в Opere :/
} else if (e.toElement && obj.contains(e.toElement)) {
 return;
}

removeClass(objGlobalParent, 'inuse');
}

function votePost(linkBtn){
linkBtn.blur();
if(matchClass(linkBtn, 'voted')) return false;

var linkGlobalParent = linkBtn.parentNode.parentNode.parentNode.parentNode;
var id = linkGlobalParent.id;
var linkParent = linkBtn.parentNode;
var rating = getElementsByClassName(linkParent, 'span', 'rating')[0].firstChild; // контейнер с рейтингом


if (matchClass(linkBtn, 'plus')){
 value = 1;
 oppositeBtn = getElementsByClassName(linkParent, 'a', 'minus')[0];  
} else {
 value = -1;
 oppositeBtn = getElementsByClassName(linkParent, 'a', 'plus')[0];
}

addClass(linkBtn, 'voted'); // отмечаем сделанный выбор
removeClass(oppositeBtn, 'voted');
addClass(linkGlobalParent, 'loading'); // ставим прелоадер

var url = "/rate/";
var data = "type=1&wtf=" + wtf_vote + "&id=" + id + "&value=" + value;
var params = {r:rating, gp:linkGlobalParent};

ajaxLoadPost(url, data, votePostonLoad, window, params, votePostonError); // отправляем/получаем данные
return false;
}

function votePostonLoad(ajaxObj, params) {
var rating = params.r;
var linkGlobalParent = params.gp;
var newRating = ajaxObj.responseText;

rating.innerHTML = newRating;
removeClass(linkGlobalParent, 'loading'); // убираем прелоадер
removeClass(rating.parentNode, 'js-loading_error');
}

function votePostonError(ajaxObj, params) {
alert(ajaxObj.statusText);
if (ajaxObj.statusText) {
 var errorText = (ajaxObj.statusText) ? ' ' + ajaxObj.statusText : '';
} else {
 var errorText = '';
}
addClass(params.r.parentNode, 'js-loading_error');
params.r.title = 'Ошибка в получении данных.' + errorText;
removeClass(params.gp, 'loading');
}

Спустя 7 часов, 38 минут, 54 секунды (14.07.2010 - 08:11) Basili4 написал(а):
Если допустимо обновление страницы то Ajax здесь вообще не нужен.

Спустя 9 часов, 55 минут, 12 секунд (14.07.2010 - 18:06) Vantedur написал(а):
Цитата (Basili4 @ 14.07.2010 - 05:11)
Если допустимо обновление страницы то Ajax здесь вообще не нужен.

не допустимо
Быстрый ответ:

 Графические смайлики |  Показывать подпись
Здесь расположена полная версия этой страницы.
Invision Power Board © 2001-2025 Invision Power Services, Inc.