### 前言
> 壓縮圖片中是非常好的,但是有些圖片 是不能壓縮的,比如圖片內容是1px的,還是循環的,壓縮后發現圖片不能使用。好好認真的看文檔,別挑著看,說看不懂。在此希望能幫助需要幫助的人。
## api說明
#### 第一步:安裝依賴
```
npm install --save tinify
```
#### 第二步:認證
> 必須先使用私鑰進行認證。這個key需要在官方網站上進行申請 api_key
```js
const tinify = require("tinify");
tinify.key = "YOUR_API_KEY";
```
##### [可選]驗證api_key 是否可用
> 此方法只是可選,可以有效校驗下是否有效
```js
const tinify = require("tinify");
tinify.key = "YOUR_API_KEY";
tinify.validate(function(err) {
if (err) throw err; // 如果拋出異常,驗證API密鑰失敗。
// 驗證成功
})
```
#### 第三步:壓縮調用方法
#### fromFile 讀取本地圖片方法
> 用于加載本地圖片,上傳到tinify服務器上,。是同步語法。
```
語法: tinify.fromFile(本地地址)
```
> 舉一個栗子:
```js
const tinify = require("tinify");
tinify.key = "YOUR_API_KEY";
// 網絡地址:
let source = tinify.fromFile('https://tinypng.com/images/panda-happy.png')
// 本地地址,比如:window的D盤demo文件夾下的一張1.png
let source = tinify.fromFile('D:\demo\1.png')
// 進行保存,可以看看下面的 toFile 或者 _url 對象
source.toFile("optimized.jpg"); // 壓縮完成后,會自動保存到本地設備項目目錄中保存 optimized.jpg 文件
```
#### fromUrl 讀取網絡圖片方法
> 加載遠程網絡地址進行壓縮。作用和 fromFile 是一樣的,都是上傳用的
```js
const source = tinify.fromUrl("https://tinypng.com/images/panda-happy.png");
source.toFile("optimized.jpg");
```
#### toFile 保存本地方法
> 通過 fromFile 或者 fromUrl 方法進行上傳,那么我們使用 toFile方法進行保存到本地。
```
語法糖: toFile(路徑+[名稱]或名稱(當前項目路徑),[error callback])
# 返回的對象是: promise 對象,也就是說,可以使用
.then(() => {
// ..... 代碼塊
})
.catch((err) => {
console.log(err)
})
```
> 舉個栗子:
```js
const tinify = require("tinify");
tinify.key = "YOUR_API_KEY";
// 本地地址,比如:window的D盤demo文件夾下的一張1.png
let source = tinify.fromFile('D:\demo\1.png')
/**
* 可以直接連著寫:
* tinify.fromFile('D:\demo\1.png').toFile('demo.png')
*/
// 不連著寫:
// source.toFile('demo.png')
// 發生異常錯誤回調寫法
source.toFile('D:\demo', function(err, sourceData) {
// 此方法用于錯誤異常回調,成功是不進行回調的
// if (err) throw err; // 簡單處理錯誤
// 詳細處理:
if (err instanceof tinify.AccountError) {// 驗證您的API密鑰和帳戶限制
console.log("The error message is: " + err.message);
} else if (err instanceof tinify.ClientError) {
//檢查圖片來源和選項。
} else if (err instanceof tinify.ServerError) {
// Tinify API出現臨時問題。
} else if (err instanceof tinify.ConnectionError) {
// 發生網絡連接錯誤。
} else {
// 其他錯誤,不是 tinify 的。
console.log(err)
}
})
.then(() => {
// ..... 代碼塊
})
.catch((err) => {
console.log(err)
})
```
| error錯誤 | 說明 |
| --- | --- |
| AccountError | 您的API密鑰或API帳戶存在問題。您的請求無法被授權。如果達到了壓縮限制,則可以等到下一個日歷月或[升級您的訂閱](https://tinypng.com/developers)。驗證API密鑰和帳戶狀態后,您可以重試該請求。 |
| ClientError | 由于提交的數據存在問題,因此無法完成請求。異常消息將包含更多信息。您不應重試該請求。 |
|ServerError | 由于Tinify API暫時存在問題,因此無法完成請求。幾分鐘后重試該請求是安全的。如果您長時間反復看到此錯誤,請[與我們聯系](mailto:support@tinify.com)。 |
| ConnectionError | 無法發送請求,因為連接Tinify API時出現問題。您應該驗證網絡連接。重試該請求是安全的。 |
**promise 對象:**
> 執行toFile 方法后,使用promise對象的 then 。
```js
tinify.fromFile('D:\demo\1.png')
toFile('D:\demo')
.then(() => {
// ..... 代碼塊
})
.catch((err) => {
console.log(err)
})
```
#### source._url 是 promise對象
> 這個是無意間發現的,官方沒有寫,當上傳完成后,可以返回臨時有效url地址。能不用這個的最好別使用,原因浪費。
- 注意:這個使用用了這個,那么 toFile 方法是不能用的。
- 注意:這個使用用了這個,那么 toFile 方法是不能用的。
- 注意:這個使用用了這個,那么 toFile 方法是不能用的。
```js
const tinify = require("tinify");
tinify.key = "YOUR_API_KEY";
let source = tinify.fromFile('https://tinypng.com/images/panda-happy.png')
source._url
.then((data) => {
console.log(data); // 返回結果:https://api.tinify.com/output/vx9735ympayt7f3q9jmpetq2m0autaat
})
.catch((err) => {
console.log(err)
})
```
#### 修改圖片信息
> 我們可以設置圖片大小、縮小(不能放大)、裁剪、
#### 保留元數據
> 保留元數據會增加壓縮文件的大小。支持保存版權信息(copyright),GPS 位置(location )、日期(creation)進行保留,不會丟失。
**preserve 方法**
> 這個方法可以將 版權信息 版權信息(copyright),GPS 位置(location )(僅JPEG)、日期(creation)進行修改。
```
const source = tinify.fromFile("large.jpg");
// 必須在fromFile處寫
const copyrighted = source.preserve("copyright", "creation");
// 必須在toFile之前
copyrighted.toFile("optimized-copyright.jpg");
```
#### 檢測壓縮數量
> 一個月有免費的500張次數,超出就得收費,在此感謝官方提供的免費500。愿你們遠離新冠病毒。
```js
let compressionsThisMonth = tinify.compressionCount; // 返回的是 number 類型
```
### Amazon S3 與 Google Cloud Storage
> 由于本人沒有 s3 與 谷歌云存儲,只能不做api嘗試了
- LOLKU
- 工具類
- form/formData
- form
- formData
- iframe
- 渲染數據,防止內存泄漏
- 獲取url(路由)參數
- 常用方法
- 失去焦點軟鍵盤頁面亂
- 判斷數據類型
- 瀏覽器全屏
- 動態插入css
- 隨機生成自定義長度位數數字
- 驗證判斷
- localStorage 封裝存儲
- 格式化日期
- 計算兩個時間差
- 去除空格
- 將駝峰命名轉換為連字符
- 獲取dom屬性
- 深拷貝
- class操作
- 判斷是否打開瀏覽器控制臺
- 全國城市地區代碼表
- canvas合成工具
- 去除emoji表情符號
- 比較兩個對象屬性和內容(值)一致
- 微信結束頁面事件
- 正則匹配url替換域名
- 字符串拼接(渲染dom后傳值)
- 判斷是否是正則
- 日歷算法
- json 工具
- 是否支持webp格式
- h5底部輸入框被鍵盤遮擋問題
- php
- php 二級域名管理
- 單個或者多個域名跨域
- file_get_contents 正確使用
- fromData請求無法攜帶cookie
- 簡單的加密文件傳輸
- css
- 1px
- 滾動
- ios點擊有顏色
- 文本溢出省略號
- css動畫抖動
- 文本換行與不換行
- 阻止旋轉屏幕時自動調整字體大小
- vue
- vscode 調試
- 新技術
- vue-router 4.0
- vue3
- 基礎
- 試驗
- javascript
- 上傳問題
- 文件選中過,第二次再次選中不觸發change事件
- 上傳oss
- 后臺
- linux搭建服務
- 需安裝
- nginx
- 安裝
- nginx http 配置二級域名
- nginx https 配置二級域名
- 防止暴力破解
- 阿里申請免費https
- git
- 快速安裝
- 配置項
- node
- 安裝
- pm2
- mysql
- 安裝
- 創建、切換、查詢數據庫
- 常用命令
- cmake 編譯器
- redis
- 軟件下載
- git
- 百度git 記住密碼
- 經驗
- 上傳
- 軟件
- vscode
- 推薦插件
- 應用開發
- nwjs
- 入門
- package.json
- vue、react、angular 跑nwjs
- 打包
- 監聽屏幕
- 運行另一個.exe文件
- node應用
- electron
- 資料
- 安裝
- 實戰
- 崩潰日志報告
- electron-forge
- 托盤閃爍
- 開機自動啟動
- 消息通知
- 禁止默認事件
- 保證只有一個實例
- 打包且美化安裝界面
- 創建cli
- 添加Github徽章
- 自動更新
- docsify
- Lowdb存儲數據
- 備份、恢復、導入、導出
- 深度鏈接(協議)喚起Electron應用
- 說明
- 加載擴展插件
- 證書
- Sketch 插件
- 工作
- 宣傳文章地址
- api
- tinypng
- npm 插件
- fs封裝:fs-jetpack
- 判斷是否npm或yarn運行
- 字符串或緩沖區的gzip壓縮大小
- 克隆并修改RegExp實例
- 反轉對象的鍵/值
- http路由find-my-way
- dragula 拖拽(拖放)
- svga
- npm 腳手架搭建
- 項目
- 小工具
- svg轉圖片
- 日歷