php+mysql+ajax の好きな関数と嫌いな関数
嫌麻烦的也可以:点击下载
HTML:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><script src="common/js/jquery.js" type="text/javascript"></script><script language="JavaScript" type="text/javascript">jQuery(function($) { //这两个是鼠标放上去的效果 $(".zhan").hover(function(){ $(this).children("b").toggle(); }); $(".cai").hover(function(){ $(this).children("b").toggle(); }); }); </script><script type="text/javascript"> <!--这两个点击事件可以改进的,因为事件问题,所以就弄了两个点击事件 $(document).ready(function(e) { //点赞(给力) $('.zhan').click(function(){ var zhan=$(this); var left = parseInt($(this).offset().left)+10, top = parseInt($(this).offset().top)-10, obj=$(this); $(this).append('<div id="zhan"><b>+1<\/b></\div>'); $('#zhan').css({'position':'absolute','z-index':'1', 'color':'#C30','left':left+'px','top':top+'px'}).animate({top:top-10,left:left+10},'slow',function(){ $(this).fadeIn('fast').remove(); var Num = parseInt(obj.find('span').text()); Num++; obj.find('span').text(Num); });$.ajax({ url:"ajax.php?action=zan", type:"post", data:"answer_id="+$(this).attr("alt"), success:function(datas){ zhan.unbind('click'); zhan.parent().parent().siblings().children().children().unbind('click'); zhan.parent().parent().siblings().children().children().attr("class","evaluate-inner"); zhan.attr("class","evaluate-inner"); } }); }); //踩(不给力) $('.cai').click(function(){ var cai=$(this); var left = parseInt($(this).offset().left)+10, top = parseInt($(this).offset().top)-10, obj=$(this); $(this).append('<div id="cai"><b>-1<\/b></\div>'); $('#cai').css({'position':'absolute','z-index':'1', 'color':'#7DAAD5','left':left+'px','top':top+'px'}).animate({top:top-10,left:left+10},'slow',function(){ $(this).fadeIn('fast').remove(); var Num = parseInt(obj.find('span').text()); Num--; obj.find('span').text(Num); }); $.ajax({ url:"ajax.php?action=cai", type:"post", data:"answer_id="+$(this).attr("alt"), success:function(datas){ cai.unbind('click'); cai.parent().parent().siblings().children().children().unbind('click'); cai.parent().parent().siblings().children().children().attr("class","evaluate-inner"); cai.attr("class","evaluate-inner"); } }); }); }); //--></script></head><body><!--给力开始--><span data-evaluate="0" id="evaluate-1908165795" class="evaluate" alog-action="qb-zan-btn"> <span class="evaluate-outer"><!-----判断对应的回答的id是否在自己创建的存储赞和踩数据的php文件,如果赞或者踩存在一个的话就不能再单击----><span class="evaluate-inner {OVOV:if $answer_datas.ans_id|in_array:$zan_list or $answer_datas.ans_id|in_array:$cai_list/}{OVOV:else/}zhan{OVOV:/if/}" alt="{OVOV:$answer_datas.ans_id/}"> <b style="display:none" class="evaluate-tip evaluate-num-fixed">给力</b> <b class="evaluate-num evaluate-num-fixed" ><span>{OVOV:$answer_datas.goods/}</span></b> </span> </span> </span><!--不给力开始--><span data-evaluate="0" id="evaluate-bad-1908165795" class="evaluate evaluate-bad" alog-action="qb-evaluate-outer"> <span class="evaluate-outer"> <span class="evaluate-inner {OVOV:if $answer_datas.ans_id|in_array:$zan_list or $answer_datas.ans_id|in_array:$cai_list/}{OVOV:else/}cai{OVOV:/if/}" alt="{OVOV:$answer_datas.ans_id/}"> <b style="display: none;" class="evaluate-tip evaluate-num-fixed">不给力</b> <b class="evaluate-num evaluate-num-fixed" style="display: inline-block;"><span>{OVOV:$answer_datas.bads/}</span></b> </span> </span> </span></div></div><!--评论回答开始--></body></html>
<?php$action=$_GET['action'];//获取get方式传过来的actionrequire_once("array/ovovsys_zan.php");switch($action){ case 'detail': /*****赞开始****/ $zan_list = json_decode(str_replace("'",'"',$zan_json),true); $zan_lists=array(); foreach($zan_list as $key=>$value){ if($value['uid']==$uid){ $zan_lists[]=$value['answer_id']; } } $smarty->assign('zan_list',$zan_lists);//查询当前登录的会员的uid对应的点赞的回答 /*****赞结束****/ /*****踩开始****/ $cai_list = json_decode(str_replace("'",'"',$cai_json),true); $cai_lists=array(); foreach($cai_list as $key=>$value){ if($value['uid']==$uid){ $cai_lists[]=$value['answer_id']; } } $smarty->assign('cai_list',$cai_lists);//查询当前登录的会员的uid对应的踩的回答 /*****踩结束****/ $smarty->display('自己的静态页面'); exit(); break;}?>
ajax文件:
<?php require_once("array/ovovsys_zan.php");//这里引用array文件夹中的数组文件$action=trim($_GET['action']);if(empty($action)){ echo '<font color=red>参数错误!</font>';exit();}switch($action){ case 'zan'://点赞(给力) //$zan_json是数组文件中设置的数组变量,存的是json数据----1 $zan_array = json_decode(str_replace("'",'"',$zan_json),true); //获取当前的会员的uid-----2 $user_answer['uid']=$uid; //获取对应的赞的回答的id----2 $user_answer['answer_id']=$_POST['answer_id']; //将会员的uid和答案的id一块的数组放到指定的数组中----3 $zan_array[]=$user_answer; $config_path = 'shuzu/ovovsys_zan.php'; if(!file_exists($config_path)){ $Base->ErrorMsg('文件错误:shuzu/ovovsys_zan.php 不存在!');exit(); } //将指定的数组转换成json数据,并且将双引号转换成单引号,不然放到数组文件中后会出错----4 $zan_new_json = str_replace('"',"'",json_encode($zan_array)); $fp = @fopen($config_path,'r+'); if(!$content = @fread($fp,filesize($config_path))){ $Base->ErrorMsg('无法读取shuzu/ovovsys_zan.php文件!');exit(); } //执行替换,将数组文件中对应的json数据----5 $content = str_replace("\$zan_json = \"{$zan_json}\"","\$zan_json = \"{$zan_new_json}\"",$content); $fp = @fopen($config_path,'w+'); @fwrite($fp,$content); //修改对应的数据表中的数据----5 $Db->ThisQuery("update `".$db_prefix."ask_answers` set `goods`=`goods`+1 where `ans_id`=".$user_answer['answer_id'].""); exit(); break; case 'cai'://踩(不给力) $cai_array = json_decode(str_replace("'",'"',$cai_json),true); $user_answer['uid']=$uid; $user_answer['answer_id']=$_POST['answer_id']; $cai_array[]=$user_answer; $config_path = 'shuzu/ovovsys_zan.php'; if(!file_exists($config_path)){ $Base->ErrorMsg('文件错误:shuzu/ovovsys_zan.php 不存在!');exit(); } $cai_new_json = str_replace('"',"'",json_encode($cai_array)); $fp = @fopen($config_path,'r+'); if(!$content = @fread($fp,filesize($config_path))){ $Base->ErrorMsg('无法读取shuzu/ovovsys_zan.php文件!');exit(); } $content = str_replace("\$cai_json = \"{$cai_json}\"","\$cai_json = \"{$cai_new_json}\"",$content); $fp = @fopen($config_path,'w+'); @fwrite($fp,$content); $Db->ThisQuery("update `".$db_prefix."ask_answers` set `bads`=`bads`-1 where `ans_id`=".$user_answer['answer_id'].""); exit(); break;}?>
对应的数据文件(因为创建数据库时没有创建踩和赞的再断,所以这里就用php文件存变量的方式保存了一下答案对应的赞和踩的数据,其中包含用户的id和答案的id)
<?php$zan_json = "";$cai_json = "";?>你没看错,就是两个变量
如果嫌复制着麻烦的话,也可以点击下载压缩文件,亲,不要积分的哟!

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











PHPには4つの主要なエラータイプがあります。1。notice:わずかなものは、未定義の変数へのアクセスなど、プログラムを中断しません。 2。警告:通知よりも深刻で、ファイルを含むなど、プログラムを終了しません。 3。ファタラー:最も深刻なのは、機能を呼び出すなど、プログラムを終了します。 4。ParseError:構文エラーは、エンドタグの追加を忘れるなど、プログラムの実行を防ぎます。

PHPでは、Password_hashとpassword_verify関数を使用して安全なパスワードハッシュを実装する必要があり、MD5またはSHA1を使用しないでください。 1)password_hashセキュリティを強化するために、塩値を含むハッシュを生成します。 2)password_verifyハッシュ値を比較して、パスワードを確認し、セキュリティを確保します。 3)MD5とSHA1は脆弱であり、塩の値が不足しており、最新のパスワードセキュリティには適していません。

PHPとPythonにはそれぞれ独自の利点があり、プロジェクトの要件に従って選択します。 1.PHPは、特にWebサイトの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンス、機械学習、人工知能に適しており、簡潔な構文を備えており、初心者に適しています。

PHPは、電子商取引、コンテンツ管理システム、API開発で広く使用されています。 1)eコマース:ショッピングカート機能と支払い処理に使用。 2)コンテンツ管理システム:動的コンテンツの生成とユーザー管理に使用されます。 3)API開発:RESTFUL API開発とAPIセキュリティに使用されます。パフォーマンスの最適化とベストプラクティスを通じて、PHPアプリケーションの効率と保守性が向上します。

HTTPリクエストメソッドには、それぞれリソースを取得、送信、更新、削除するために使用されるGET、POST、PUT、および削除が含まれます。 1. GETメソッドは、リソースを取得するために使用され、読み取り操作に適しています。 2. POSTメソッドはデータの送信に使用され、新しいリソースを作成するためによく使用されます。 3. PUTメソッドは、リソースの更新に使用され、完全な更新に適しています。 4.削除メソッドは、リソースの削除に使用され、削除操作に適しています。

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

Phpoopでは、self ::は現在のクラスを指し、親::は親クラスを指し、静的::は後期静的結合に使用されます。 1.Self ::静的方法と一定の呼び出しに使用されますが、後期静的結合をサポートしていません。 2.Parent ::サブクラスには、親クラスのメソッドを呼び出すために使用され、プライベートメソッドにアクセスできません。 3.Static ::継承と多型に適した後期静的結合をサポートしますが、コードの読みやすさに影響を与える可能性があります。

PHPは、$ \ _ファイル変数を介してファイルのアップロードを処理します。セキュリティを確保するための方法には次のものが含まれます。1。アップロードエラー、2。ファイルの種類とサイズを確認する、3。ファイル上書きを防ぐ、4。ファイルを永続的なストレージの場所に移動します。
