ホームページ バックエンド開発 PHPチュートリアル 論理的な判断だけでは目的は達成できない

論理的な判断だけでは目的は達成できない

Jun 13, 2016 pm 01:21 PM
class news php title

論理的な判断だけでは目的を達成できません。助けてください
ニュース システムの 3 つの機能を 1 つのページだけで表示したいのですが、「index.php?news_title=xxx?news_class=xxx」。目標を達成する必要があります:

1. news_title 要素と news_class 要素が両方とも空であるか、値がある場合、ページにはすべてのニュースのタイトル リストが表示されます。

2. news_title と news_class の場合、一方には値があり、もう一方には値がありません。要素に値があるコンテンツがページに表示されます。

------アルゴリズム ロジックとコードの実装:

PHP コード
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
//首先,取得浏览器的传值:news_title和news_class
if(isset($_GET['news_class']))
{
  $news_class=$_GET['news_class'];
}
else
{
  $news_class='';
}
 
if(isset($_GET['news_title']))
{
  $news_title=$_GET['news_title'];
}
else
{
  $news_title='';
}

//然后开始判断,准备显示有关的内容

if ($news_title='')//当news_title元素为空时,开始判断news_class元素是否为空
{
   if ($news_class='')//news_class也为空,则该页面显示所有news表的news_title列表
    {
      $sql="SELECT news_title,in_time FROM news";
      $result = mysql_query($sql);
       while ($row=mysql_fetch_assoc($result))
             {
?>             
        <tr>
          <td>
        <?php echo $row['news_title']; ?>
        <?php echo $row['in_time']; ?>
      </td>
        </tr>
<?php
             }
mysql_free_result($result);
    }
    else//当news_class不为空,则该页面显示news_class的相关内容
    {
      $sql="SELECT * FROM news where news_class='$news_class'";
      $result = mysql_query($sql);
       while ($row=mysql_fetch_assoc($result))
             {
?>             
        <tr>
          <td><?php echo $row['news_title']; ?>
              <?php echo $row['in_time']; ?>
          </td>
        </tr>
<?php
             }
mysql_free_result($result);
    }
}
else  //当news_title不为空值时,开始判断news_class是否为空
{
   if ($news_class='')//news_class为空,则该页面show出news_title的相关数据
    {
      $sql="SELECT * FROM news where news_title='$news_title'";
      $result = mysql_query($sql);
       while ($row=mysql_fetch_assoc($result))
             {
?>             
        <tr>
          <td> <?php echo $row['news_title']; ?>
               Author : <?php echo $row['news_author']; ?> 
               Date : <?php echo $row['in_time']; ?> 
                      <?php echo $row['news_content']; ?>
      </td>
        </tr>
<?php
             }
mysql_free_result($result);      
    }
    else//当news_class也不为空值时,则该页面显示所有news表的数据(和两者都为空时一样)
    {
      $sql="SELECT news_title,in_time FROM news";
      $result = mysql_query($sql);
       while ($row=mysql_fetch_assoc($result))
             {
?>             
        <tr>
          <td><?php echo $row['news_title']; ?>
          <?php echo $row['in_time']; ?>
      </td>
        </tr>
<?php
             }
mysql_free_result($result);      
    }
}

ログイン後にコピー


上記のコードが最終的に表示されると、すべてのコードが表示されます。ニュースとして表示されるタイトルリストは new_title list です。

皆さんにお聞きしたいのですが、私の論理が間違っている、あるいは私の書き方に何か問題がありますか?


-----解決策---------
書けませんかこんな感じですか?

要求されたデータ、ロジック、パフォーマンスの HTML コードはすべてまとめられています。
最初に論理的に判断することが最善です。もう一度データをリクエストしてください。最後の foreach は html を出力します。

あなたのコードは非常に難しいので、最初から始めたほうが良いでしょう。 =_=zzz
------解決策---------
index.php?news_title=xxx?news_class= xxx
のパラメータ文字列は従来の形式ではありません
従来の形式は、index.php?news_title=xxx&news_class=xxx

得られるものは array( 'news_title' => 'xxx? news_class=xxx')
使用前に処理が必要です

------解決策---------
PHP コード
if ($a && $b) {
    // すべて表示
elseif ($a) {
    ;
elseif ($b) {
    ;
}
<br><font color="#e78608">------解決策---------</font><br>URL は、index.php?news_title= として記述する必要があります。 xxx&news_class =xxx<br><br>$news_title = $news_class = '';<br>if(isset($_GET['news_title'])) $news_title = $_GET['news_title'];<br>if( isset ($_GET['news_class'])) $news_class = $_GET['news_class'];<br><br>if($news_title != '' && $news_class != '') {<br> // 2 つすべて <div class="clear"></div>
ログイン後にコピー
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

CakePHP プロジェクトの構成 CakePHP プロジェクトの構成 Sep 10, 2024 pm 05:25 PM

この章では、CakePHP の環境変数、一般設定、データベース設定、電子メール設定について理解します。

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP ルーティング CakePHP ルーティング Sep 10, 2024 pm 05:25 PM

この章では、ルーティングに関連する次のトピックを学習します。

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 Dec 20, 2024 am 11:31 AM

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

CakePHP バリデータの作成 CakePHP バリデータの作成 Sep 10, 2024 pm 05:26 PM

Validator は、コントローラーに次の 2 行を追加することで作成できます。

See all articles