php文件與HTML頁面的數據交互

来源:https://www.cnblogs.com/shiyiaccn/archive/2018/12/17/10132151.html
-Advertisement-
Play Games

php獲取HTML頁面返回的數組並寫入文檔以及HTML頁面通過json獲取php的變數。 ...


註意:首先需要保證本地配置了php開發環境,如WAMP開發環境

WAMP配置:https://www.cnblogs.com/shiyiaccn/p/9984579.html

 

php獲取HTML頁面返回的數組並寫入文檔

 

HTML發送使用POST發送)

 

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>無標題文檔</title>
</head>

<body>
    <div class='search-choose' id='search_choose'>
        <ul> 
            <li id='search_1' class='search-selected'><a href='#'>dog</a></li>
            <li id='search_2'><a href='#'>cat</a></li>
        </ul>
    </div>
    
    <script type='text/javascript'>
      searchArray = document.getElementsByTagName('li');//獲取名字為’li’的所有標簽項並存入數組
      var writeArray = [];
      for(var i = 0;i<searchArray.length;i++){
          writeArray[i] = searchArray[i].innerText;//獲取標簽內容writeArray = ['dog','cat'];
      }
    
      //使用POST將數組writeArray發送到php文件servertest.php
      var request = new XMLHttpRequest();
      request.open("POST", "servertest.php");
      var q = "data=" + writeArray;//  q="name"+ value;
      //發送內容體由name+value組成,此處name為data,value為writeArray
      request.setRequestHeader("Content-type","application/x-www-form-urlencoded");
      request.send(q);
      request.onreadystatechange = function() {
          if (request.readyState===4) {
          if (request.status===200) { 
          } else {
                  alert("發生錯誤:" + request.status);
              }
          } 
      }
    </script>
</body>
</html>

 

:關鍵操作

var request = new XMLHttpRequest();

request.open("POST", "servertest.php");

var q = "data=" + writeArray;// 生成信息體q = “name “+ value

request.setRequestHeader("Content-type","application/x-www-form-urlencoded");

request.send(q);

//HTML頁面POST發送內容後,php通過超全局變數 $_GET $_POST收集

 

php接收(使用超全局變數$_GET $_POST收集

<?php
//設置頁面內容是html編碼格式是utf-8
header("Content-Type: text/plain;charset=utf-8"); 
//判斷如果是get請求,則執行getMethod();;如果是POST請求,則執行postMethod()。
//$_SERVER是一個超全局變數,在一個腳本的全部作用域中都可用,不用使用global關鍵字
if ($_SERVER["REQUEST_METHOD"] == "GET") {
    getMethod();
} elseif ($_SERVER["REQUEST_METHOD"] == "POST"){
    postMethod();
}
function searchShow(){    
}
function postMethod(){
    $filename = 'save.txt';
//使用超全局變數 $_GET 和 $_POST收集name對應的value,如下
    $searchWrite = $_POST["data"];
//將獲取的HTML返回內容$searchWrite寫入文檔save.txt
    file_put_contents($filename, $searchWrite);
    $content = file_get_contents($filename);
    echo $content;
}

:關鍵操作

$searchWrite = $_POST["data"]

使用超全局變數 $_POST收集name對應的value放入$searchWrite,於是得到了HTML頁面發送的數據,可以用了

 

HTML頁面通過json獲取php的變數

 

php發送(通過echo返回json格式的數據對)

<?php
header('Access-Control-Allow-Origin:*');
header('Access-Control-Allow-Methods:POST,GET');
header('Access-Control-Allow-Credentials:true'); 
header("Content-Type: application/json;charset=utf-8"); 
if ($_SERVER["REQUEST_METHOD"] == "GET") {
    getMethod();
} elseif ($_SERVER["REQUEST_METHOD"] == "POST"){
    postMethod();
}
function getMethod(){    
    $filename = 'search_save.txt';//假設文件內容為dog,cat,pig,人
    if (file_exists($filename)) {
        $content = file_get_contents($filename);
        $pattern = '/[\x{4e00}-\x{9fa5}_a-zA-Z0-9]+/u';
        //[\x{4e00}-\x{9fa5}_a-zA-Z0-9]匹配中文、下劃線、字母、數字
        preg_match_all($pattern, $content, $matches);
        $searchRead = $matches[0];//通過正則表達式提取存儲列表到$searchRead數組['dog','cat','pig','人']
        $defaultSearch = $searchRead[0];
        $result = '{"success":false,"defaultSearch":""}';
        if($_GET["data"]){
            $result = '{"success":true,"defaultSearch":"'.$defaultSearch.'"}';
        }
    }
    echo $result;//echo返回json格式化數據對{"success":true,"defaultSearch":"'.$defaultSearch.'"}
 } 
functionpostMethod(){
}

:關鍵操作

$result = '{"success":true,"defaultSearch":"'.$defaultSearch.'"}';//將待返回內容改為json格式

   echo $result;//HTML頁面的json部分將從echo的輸出獲取json格式化數據對,因此echo輸出內容需要為json格式

HTML接收通過GET接收php echo返回的json格式的數據對)

<script type='text/javascript'>
        $(document).ready(function(){ 
            $.ajax({ 
                type: "GET",     
                url: "default_search.php?data=" + value,//value為HTML向url發送的內容體,在php中可以通過超全局變數收集
                dataType: "json",
               //data為php使用echo返回的json格式的數據對,通過data.name的形式即可以使用name對應的value
           success: function(data) {
            if (data.success) { 
              alert(data.defaultSearch);            
            } 
          },
                error: function(jqXHR){     
                   alert("發生錯誤:" + jqXHR.status);  
                },     
            });
        });
</script>

:關鍵操作

$.ajax({

   type: "GET",

        url: "default_search.php?data=" + "searchArray",

        dataType: "json",

        success: function(data) {

       If(data.success){alert(data.defaultSearch);}

//dataphp使用echo輸出的json格式的數據對,通過data.name的形式即可以使用name對應的value

         },

         error: function(jqXHR){     

           alert("發生錯誤:" + jqXHR.status);  

         },     

    });

});

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • [TOC] 一. 響應式編程 響應式編程,也稱為流式編程,對於非前端工程師來說,可能並不是一個陌生的名詞,它是 函數式編程 在軟體開發中應用的延伸,如果你對函數式編程還沒有一些感性的認知,那麼建議你先閱讀我曾經寫過的一篇入門文章 "【javascript基礎修煉(8)——指向FP世界的箭頭函數】" ...
  • 1.閉包:函數在調用的時候會形成一個私有的作用域,對內部變數起到保護的作用,這就是閉包。 2.變數銷毀: 1.人為銷毀 var a=12; a=null 2.自然銷毀 函數調用完成之後 瀏覽器會自動銷毀函數內的變數 3.閉包的作用? 1.保護變數 2.緩存數據 緩存數據有優勢也有劣勢:優勢是緩存數據 ...
  • 1.瀏覽器解析JavaScript原理特點: 1.跨平臺 2.弱類型 javascript 定義的時候不需要定義數據類型,數據類型是根據變數值來確定的. var a = 10; 數字類型 var a = true boolean類型 ( 強類型: 定義變數的時候需要定義變數的類型:例如java,C# ...
  • 預編譯的兩種情況 全局: 1.全局 直接是script標簽中的代碼,不包括函數執行 執行前: 1.首先生成一個GO(global object)對象,看不到,但是可以模擬出來用來分析 2.分析變數聲明,變數名為屬性名,值為undefined 3.分析函數聲明,函數名為屬性名,值為函數體,如果函數名和 ...
  • 本文由雲+社區發表 本文將通過三個簡單的實例,實際應用上篇文章的基礎理論知識,展示下Flex佈局是如何解決CSS佈局問題。 一.垂直居中 這裡同時用非flex佈局和flex佈局兩種方式來實現,可以對比兩種實現方式的差異。 1.1用margin實現垂直居中 實現方式: 父元素採用相對定位,子元素採用絕 ...
  • 1.萬物皆為對象 提起函數首先要知道對象,而對象又是js數據類型中的一種,所以我們從頭開始。 1)javascript數據類型有哪些? 原始數據類型:number,undefined,null,string,boolean 引用數據類型:object 2)數據類型的檢測: typeof(需要檢測的內 ...
  • UED User Experience Design(用戶體驗設計),簡稱UED。UED是以用戶為中心的一種設計手段,以用戶需求為目標而進行的設計。設計過程註重以用戶為中心,用戶體驗的概念從開發的最早期就開始進入整個流程,並貫穿始終。由於用戶體驗是一種用戶在使用一個產品(服務)的過程中建立起來的純主 ...
  • 1、流動模型(Flow) 流動(Flow)是預設的網頁佈局模式。也就是說網頁在預設狀態下的 HTML 網頁元素都是根據流動模型來分佈網頁內容的。 流動佈局模型具有2個比較典型的特征: (1)塊狀元素都會在所處的包含元素內自上而下按順序垂直延伸分佈,因為在預設狀態下,塊狀元素的寬度都為100%。 (2 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...