検索
ホームページバックエンド開発PHPチュートリアルセカンダリディレクトリのドラッグ&ドロップソートの実装について(ソースコードサンプルダウンロード)_PHPチュートリアル

セカンダリディレクトリのドラッグ&ドロップソートの実装について(ソースコードサンプルダウンロード)_PHPチュートリアル

Jul 21, 2016 pm 03:12 PM
ダウンロードレベル2について存在する成し遂げる開発する引っ張る選別ソースコード目次

第 2 レベルのディレクトリ形式は、開発プロジェクトでよく使用されます。たとえば、記事モジュールや製品モジュールなど、多くのアプリは 2 レベルの分類形式に基づいています。通常の並べ替えソリューションでは、1段階分類でも多段階分類でも、管理者がバックグラウンドで同レベル分類の値を手動で編集して並べ替えを設定し、その値に基づいて表示順序が決定されます。この操作方法は比較的面倒です。 jQuery はドラッグ アンド ドロップで並べ替えを行うことができ、ユーザー レベルでは非常に直感的で簡単に操作できます。プロジェクトでは、製品分類が 2 段階の分類を使用しており、表示は下図のようになります。

並べ替えの問題に関しては、jQuery のドラッグ アンド ドロップ プラグインを使用することにしました。最初のレベルのカテゴリをドラッグすると、特定のレベルのカテゴリの下にあるサブカテゴリをドラッグすると、最初のレベルのカテゴリが並べ替えられます。サブカテゴリはドラッグ アンド ドロップで並べ替えられます。

第 1 レベルのカテゴリ名のフロントデスクにある「+」アイコンをドラッグして、第 1 レベルのカテゴリを並べ替えます。

特定レベルの分類の下にある第 2 レベルのカテゴリの名前の前にある「-」アイコンをドラッグして、このカテゴリの下にある第 2 レベルのカテゴリを並べ替えます。

以下は、上記の機能を実現するためのデータベース構造とプログラムコードです

​​

データベース構造



コードをコピー

コードは次のとおりです:CREATE TABLE IF NOT EXISTS `product_classify` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`parentId` int(10) unsigned NOT NULL ,
` name` varchar(50) DEFAULT NULL,
`sort` int(10) unsigned NOT NULL DEFAULT '0',
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=27 DEFAULT CHARSET=utf8;



データをインポート


コードをコピー
コードは次のとおりです:INSERT INTO `product_classify` (`id`, `parentId`, `name`, `sort`) VALUES
(1, 0, 'マジック小道具' , 1),
(2, 1, 'クローズアップマジック', 2),
(3, 1, 'ステージマジック', 1),
(4, 1, '劉銭マジック' ', 3),
(5, 0, '銭州小道具', 2),
(6, 5, '麻雀パイガウシリーズ', 3),
(7, 5, 'ポーカーシリーズ', 1),
(8, 5, 'サイズ シリーズ' ', 5),
(9, 5, 'カード チェンジャー シリーズ', 4),
(10, 5, 'ハイテク シリーズ', 2);



スタイルコード


コードをコピー
コードは次のとおりです:





jsファイルとコードをロードします

コードをコピーします
コードは次のとおりです:



<script><BR>$(document).ready(function(){<BR> $("#mm ").sortable({<BR> 不透明度: 0.5,<BR> カーソル:'move',<BR> revert:true,<BR> ハンドル:'.f',<BR> プレースホルダー:'ui-move',<BR> update:function(){<BR> serial= $(this).sortable("serialize");<BR> $("#return").load("myRun/sort.php?"+serial);<BR> }<BR> });<BR> $("#mm div") .sortable({<BR> 不透明度: 0.5,<BR> カーソル:'move',<BR> revert:true,<BR> ハンドル:'.t',<BR> プレースホルダー:'ui-move',<BR> update:function(){<BR> serial=$( this).sortable("serialize");<BR> $("#return").load("myRun/sort.php?"+serial);<BR> }<BR> });<BR> $(".f").toggle( function(){<BR> if($(this).attr("src")=='images/plus.gif'){<BR> $("#mm").find(".f").attr("src ","images/plus.gif");//将全部大类上の图标改は加号<BR> $("#mm").find("div").hide();//隐藏子类<BR> $('div',$(this).parents('.nav:first')).show();//显示当前点击大类的子类<BR> $(this).attr("src","images /nofollow.gif");// 将当前点击的大类上の加号图标変更减号图标<BR> }else{<BR> $(this).attr("src","images/plus.gif"); <BR> $('div',$(this).parents('.nav:first')).hide();//$($(this).parents('div:first')+'.odd2') .hide();<BR> }<BR> },function(){<BR> if($(this).attr("src")=='images/plus.gif'){<BR> $("#mm").find( ".f").attr("src","images/plus.gif");<BR> $("#mm").find("div").hide();<BR> $('div',$( this).parents('.nav:first')).show();<BR> $(this).attr("src","images/nofollow.gif");<BR> }else{<BR> $(this).attr ("src","images/plus.gif");<BR> $('div',$(this).parents('.nav:first')).hide();//$($(this). parents('div:first')+'.odd2').hide();<BR> }<BR> });<BR> //$('.odd2','table:first').hide();//初化隐藏メイン クラス <-- 変更: CSS で子クラスを表示:なしにします。これにより、最初の 1 つが直接表示されます。 $('#mm ul:first div').show();//显示第一主题分类列表<BR> $('#mm ul:first .f').attr("src","images/nofollow. gif");//改变图片は“-”状態<BR>});<BR></script>


显表示代
复制代代価如下:



//どこより条件来过滤子类,仅表示分类(一级)
$sql='a.id,a.parentId,a.name,a.sort,count(b.id) を product_classify からのカウントとして選択';
$sql.=' left join product_classify as b on b.parentId=a.id where a.parentId=0';
$sql.=' a.id でグループ化 a.sort で並べる';
$query=mysql_query( $sql);
if(mysql_num_rows($query)){
while($arr=mysql_fetch_array($query)){
echo '";
}
}else{
echo '';
}
?>


排序操作sort.php
复制代码代码如下:

include("../conn.php") ;
$menu=$_GET['menu'];
switch(strto lower($menu[0])){
case 'productclassify':
$table='product_classify';
break;
}
for($i =1;$i $sql='UPDATE '.$table.' SET ソート=' 。 $i 。 ' WHERE id=' 。 $menu[$i];
mysql_query($sql);
}
?>

实例下ダウンロード
二级目录拖拽排序的实现及演演示源网下ダウンロード

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/326774.html技術記事一般的な解決順序は、文章モジュールや製品モジュールのように、2 つの階層形式に基づいています。
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPセッションを失敗させる可能性のあるいくつかの一般的な問題は何ですか?PHPセッションを失敗させる可能性のあるいくつかの一般的な問題は何ですか?Apr 25, 2025 am 12:16 AM

PHPSESSIONの障害の理由には、構成エラー、Cookieの問題、セッションの有効期限が含まれます。 1。構成エラー:正しいセッションをチェックして設定します。save_path。 2.Cookieの問題:Cookieが正しく設定されていることを確認してください。 3.セッションの有効期限:セッションを調整してください。GC_MAXLIFETIME値はセッション時間を延長します。

PHPでセッション関連の問題をどのようにデバッグしますか?PHPでセッション関連の問題をどのようにデバッグしますか?Apr 25, 2025 am 12:12 AM

PHPでセッションの問題をデバッグする方法は次のとおりです。1。セッションが正しく開始されるかどうかを確認します。 2.セッションIDの配信を確認します。 3.セッションデータのストレージと読み取りを確認します。 4.サーバーの構成を確認します。セッションIDとデータを出力し、セッションファイルのコンテンツを表示するなど、セッション関連の問題を効果的に診断して解決できます。

session_start()が複数回呼び出されるとどうなりますか?session_start()が複数回呼び出されるとどうなりますか?Apr 25, 2025 am 12:06 AM

session_start()への複数の呼び出しにより、警告メッセージと可能なデータ上書きが行われます。 1)PHPは警告を発し、セッションが開始されたことを促します。 2)セッションデータの予期しない上書きを引き起こす可能性があります。 3)session_status()を使用してセッションステータスを確認して、繰り返しの呼び出しを避けます。

PHPでセッションのライフタイムをどのように構成しますか?PHPでセッションのライフタイムをどのように構成しますか?Apr 25, 2025 am 12:05 AM

PHPでのセッションライフサイクルの構成は、session.gc_maxlifetimeとsession.cookie_lifetimeを設定することで達成できます。 1)session.gc_maxlifetimeサーバー側のセッションデータのサバイバル時間を制御します。 0に設定すると、ブラウザが閉じているとCookieが期限切れになります。

セッションを保存するためにデータベースを使用することの利点は何ですか?セッションを保存するためにデータベースを使用することの利点は何ですか?Apr 24, 2025 am 12:16 AM

データベースストレージセッションを使用することの主な利点には、持続性、スケーラビリティ、セキュリティが含まれます。 1。永続性:サーバーが再起動しても、セッションデータは変更されないままになります。 2。スケーラビリティ:分散システムに適用され、セッションデータが複数のサーバー間で同期されるようにします。 3。セキュリティ:データベースは、機密情報を保護するための暗号化されたストレージを提供します。

PHPでカスタムセッション処理をどのように実装しますか?PHPでカスタムセッション処理をどのように実装しますか?Apr 24, 2025 am 12:16 AM

PHPでのカスタムセッション処理の実装は、SessionHandlerInterfaceインターフェイスを実装することで実行できます。具体的な手順には、次のものが含まれます。1)CussentsessionHandlerなどのSessionHandlerInterfaceを実装するクラスの作成。 2)セッションデータのライフサイクルとストレージ方法を定義するためのインターフェイス(オープン、クローズ、読み取り、書き込み、破壊、GCなど)の書き換え方法。 3)PHPスクリプトでカスタムセッションプロセッサを登録し、セッションを開始します。これにより、データをMySQLやRedisなどのメディアに保存して、パフォーマンス、セキュリティ、スケーラビリティを改善できます。

セッションIDとは何ですか?セッションIDとは何ですか?Apr 24, 2025 am 12:13 AM

SessionIDは、ユーザーセッションのステータスを追跡するためにWebアプリケーションで使用されるメカニズムです。 1.ユーザーとサーバー間の複数のインタラクション中にユーザーのID情報を維持するために使用されるランダムに生成された文字列です。 2。サーバーは、ユーザーの複数のリクエストでこれらの要求を識別および関連付けるのに役立つCookieまたはURLパラメーターを介してクライアントに生成および送信します。 3.生成は通常、ランダムアルゴリズムを使用して、一意性と予測不可能性を確保します。 4.実際の開発では、Redisなどのメモリ内データベースを使用してセッションデータを保存してパフォーマンスとセキュリティを改善できます。

ステートレス環境(APIなど)でセッションをどのように処理しますか?ステートレス環境(APIなど)でセッションをどのように処理しますか?Apr 24, 2025 am 12:12 AM

APIなどのステートレス環境でのセッションの管理は、JWTまたはCookieを使用して達成できます。 1。JWTは、無国籍とスケーラビリティに適していますが、ビッグデータに関してはサイズが大きいです。 2.cookiesはより伝統的で実装が簡単ですが、セキュリティを確保するために慎重に構成する必要があります。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境