[TOC]
# PHP調試助手Kint
> 當調試PHP代碼時,var_dump()、print_r()和debug_backtrace()是我們最常用的工具。Kint,一個開源軟件,一個不需安裝的替代者,它提供了更好的調試體驗。它巧妙地檢測幾乎不可讀的數據,并將它們定制成規則的輸出顯示。變量名、文件、行號及包裝的函數它全能提示出來。
* ## PHP 調試函數
~~~
print_r()
var_dump()
debug_backtrace()
~~~
> 介紹給大家一個很好用的PHP DEBUG工具---Kint http://raveren.github.io/kint/ 在這個主頁上你幾乎能獲取到所有關于它的信息了,我在這里只是對這個工具及其使用做個簡要介紹。
它是一個無需安裝的,易用的,強力的PHP調試助手,它能很好的替代var_dump(),print_r(),debug_backtrace()這些函數。
它設計的目的就是在調試時能將數據以最好的方式呈現給你。
* ## 安裝和使用
### 1. 需求:
需要PHP 5+(額外的功能需要5.3+),現代的瀏覽器。
### 2.下載和安裝:
下載在Kint的主頁,下載后將Kint目錄按你的想法隨意放置,接著只需要將 Kint.class.php 包含進來就可以開始了!
### 3.快速入門:
~~~
[php] view plain copy
1. <?php
2. require '/kint/Kint.class.php';
3.
4.
5. Kint::dump( $_SERVER );
6. // 或許,可以試試更簡單的,使用縮寫:
7. d( $_SERVER );
8. // 或者,你可以用dd()在打印完之后直接結束程序;
9. dd( $_SERVER ); // 相當于 d( $_SERVER ); die;
10.
11.
12. // 跟蹤調試信息:
13. Kint::trace();
14. // 這么寫跟上面的效果相同
15. Kint::dump( 1 );
16.
17.
18. // 禁用所有輸出
19. Kint::enabled(false);
20. // 之后這樣的方法調用,都不會有輸出了
21. d('Get off my lawn!'); // 沒有效果
~~~
### 4.配置
你可以將默認配置 config.default.php 重命名成 config.php,這樣你自己的配置就會覆蓋默認配置了。在配置文件中,每一項都有詳細的說明。
### 5.進階用法
> 文本輸出
可以只輸出文本信息,而不是像之前那樣的格式化樣式
~~~
1. <?php
2. s( $variable );
3. // 還有
4. sd( $variable ); // 輸出完直接退出,還記得上面的dd()嗎
~~~
> 實時修飾符
~~~
1. <?php
2. +Kint::dump( $variable );
3. // 或者這么寫
4. +d( $variable );
~~~
> 可用的修飾符有:
> ● +Kint::dump(); 將會忽視嵌套層次限制
> - 當你輸出一個特別負責的對象(比如說嵌套層次很深的數組時),你會收到一個 *DEPTH TOO GREAT* 的信息,用這個修飾> 符可以忽略掉這個限制;
> - 警告:可能引起瀏覽器異常
> ● -Kint::dump(); 將會清除在這之前的所有輸出信息
> - 在頁面頂端顯示;
> - 當變量在HTML中時,使用這個會特別有用,與dd()一起使用也很有效果;
> - 在ob_clear() 和 ob_start() 環境中使用可能會失效;
> ● @Kint::dump(); 將會返回Kint::dump()的值,而不是打印結果,可以參考print_r(, true);
> - 可以用來記錄日志;
> ● !Kint::dump();輸出結果將會自動展開,你不用手動去點了。
* * * * *
### 6.Kint使用
~~~
<php?
//加載Kint
require('Kint.class.php');
//打印$_POST,在瀏覽器上顯示的打印信息特別有條理,看起來特別舒服
//果斷拋棄var_dump,echo......
Kint::dump($_POST);
//打印代碼運行至此處的調用鏈,比debug_backtrace清晰多了
Kint::trace();
//特殊語法
//打印$_POST,默認在瀏覽器上展開所有輸出
!Kint::dump($_POST);
//打印$_POST,清除調用之前的所有輸出
-Kint::dump($_POST);
//打印$deepObject,如果參數比較復雜,建議使用該函數
+Kint::dump($deepObject);
~~~
- 關于我們
- ApiCloud
- 支付模塊
- 微信支付--wxPay(客戶端)
- 微信支付--wxPay(服務端)
- 支付寶支付--aliPay(客戶端配置)
- 支付寶支付--aliPay(服務端配置)
- DoT模板
- 緩存模塊
- 監聽模塊
- 百度定位模塊
- 設置狀態欄字體顏色
- 選擇城市插件
- 跨頁面執行方法
- 安卓-點擊返回事件
- 上傳圖片模塊
- 點擊彈出放大圖片層
- 魅族手機apiready問題
- 分享
- 跨win或frm執行腳本
- 關于ios數字自動識別成手機號
- 百度地圖bMap
- 語音識別模塊
- tabBarMenu底部導航
- 第三方登錄
- QQ網站和appQQ賬號的統一問題解決
- 微信登錄
- QQ登錄
- 微博登錄
- 上拉加載、下拉刷新模塊
- 圖片緩存
- 文件和圖片緩存機制分享
- PHP
- 支付寶及時到賬
- no input file specified報錯解決
- thinkphp 整合kindeditor
- 整合tpshop微信模塊到thinkcmf中
- thinkphp3.1.3整合支付寶
- 網站接入QQ OAuth2.0登錄教程
- ThinkPHP整合百度編輯器Ueditor
- PHP加快執行效率的寫法規范
- ThinkPHP操作大全
- PHP操作大全
- Thinkphp中SQL操作返回值
- php5.3 foreach 使用&(與運算符)引用賦值要注意的問題
- mysql給字段追加值
- 阿里大魚短信平臺接入
- Navicat 導出 Mysql 數據字典
- php 面向對象全面教程
- PHP5下調用SOAP
- PHP處理時間格式添加空格
- 偽裝URL請求(.htaccess)
- url請求參數加解密
- JS插件
- artDialog彈窗-頁面傳值
- jQuery點擊遮罩彈出層固定居中
- jeBox原生彈窗
- bxslider輪播
- js生成指定位數隨機數
- 發送短信倒計時
- js調試
- jQuery.validator 表單驗證規則
- Swiper 輪播
- 獲得焦點時-圖片抖動
- uploadify無刷新上傳圖片
- 導航下拉隱藏上拉顯示
- 獲得焦點時-加黑色蒙版
- jquery.qrcode.js生成二維條形碼(支持中文)
- jquery.qrcode.js生成二維條形碼(官方不支持中文)
- nth-child 選擇器
- 無刷新點擊實現加載更多數據
- 刷新頁面方法
- 判斷滾動條向上向下
- 跨瀏覽器復制jQuery-zclip
- js校驗表單后提交表單的三種方法
- 用JS判斷下拉框是否選中
- div中滾動
- 提交時彈出模態框
- 當圖片不顯示時替換方法
- 前端
- CSS3
- HTML5
- css技巧
- 移動端rem
- Flex布局
- 電商詳情滾動條監聽
- VueCircleMenu圓環按鈕
- iframe自適應頁面高度
- 百度Echart
- input:radio改變選中顏色
- Jquery
- 響應式布局基本實現Media Query
- 循環輸出只輸出新內容
- 小程序
- wx.request坑
- 概要
- git操作
- 本地記住密碼
- 操作
- 生成ssh公鑰 記住密碼
- git避坑
- ES6學習手札
- 調試小插件
- 谷歌插件Postman
- PHP調試助手
- WordPress
- 緩存服務器Redis
- 在線代碼運行 Docker
- 在ubuntu下怎樣安裝https
- BrowserSync 瀏覽器同步測試工具
- getmarkman高效的設計稿標注、測量工具
- PHPstrom軟件
- 服務器
- linux 安裝搭建服務器配置及nginx配置
- tpshop的nginx 服務器配置方法
- (服務器訪問文件404解決辦法)IIS 之 添加MIME擴展類型及常用的MIME類型列表
- mysql部分
- mysql緩存
- MySql監控工具--mytop
- MySql主從搭建
- mysql優化
- Mysql 復制 (主從復制)
- iOS開發筆記 - 上線流程
- VUE避坑指南
- 從零開始學Vue
- Vue-cli
- Webpack
- VUE小記
- npm打包空白
- 打包背景圖片/項目圖片不顯示
- VUE避坑指南/elementUI upload 自定義http-request上傳
- 關于watch監聽路由重復加載方法
- 解決加載內容的時候閃動問題
- vuecli沒有network訪問地址
- python學習
- python初始
- pytho內置函數大全
- win10 播放器播放TS文件問題
- 設計網站
- VUE避坑指南/VUE-CLI部署空白
- swiper使用問題
- uni-app學習手冊
- 目錄結構
- layUI
- nodesass版本sassloader版本問題