### 啟動白屏(和設置的窗口顏色一樣的顏色)
> 原因:在窗口對象中設置顏色,啟動程序是先顯示窗口在加載,那么就看到了窗口設置的。
>解決方案:先進行隱藏窗口,當加載完成后,進行顯示窗口即可
```js
mainWindow = new BrowserWindow({
minHeight: 650,
height: 650,
show: false, // 1、解決啟動后白屏:先隱藏
})
// 2、在此聲明周期中打開
mainWindow.on('ready-to-show', function () {
mainWindow.show()?//?3、解決啟動后白屏:初始化后再顯示
})
```
### 開啟設備攝像頭
> 需要申請權限。
- https://www.bugs.cc/p/electron-app-request-camera-and-microphone-permission-by-macos/
- http://chenhaichao.cn/showmarkdown/15
- https://github.com/Azure/BatchExplorer/blob/master/electron-builder.yml
### 拒絕多個同一個程序啟動(單個窗口)
> 同一個程序只能開一個窗口,其他的只能關閉。比如,一個程序雙擊后啟動一個,但是如果多次雙擊會啟動多個。
~~~js
const gotTheLock = app.requestSingleInstanceLock()
if (!gotTheLock) {
app.quit()
}
~~~
> 第二個版本
``` js
const gotTheLock = app.requestSingleInstanceLock()
if (!gotTheLock) {
app.quit()
} else {
app.on('second-instance', (event, commandLine, workingDirectory) => {
// 當運行第二個實例時,將會聚焦到mainWindow這個窗口
if (mainWindow) {
if (mainWindow.isMinimized()) mainWindow.restore()
mainWindow.focus()
mainWindow.show()
}
})
}
```
## 制作菜單欄
### 第一步:去除邊框窗口
> 底層部分,設置frame為false。frame默認為true
```js
mainWindow = new BrowserWindow({
height: 563,
useContentSize: true,
width: 1000,
frame: false // 設置false為去除邊框
})
```
### 第二步:自定義布局
> 布局部分
```html
<section id="kw">
<h1>Hello World!</h1>
<div class="noDrag" ondragover="dragover(event)" ondrop="drop(event)">
<button type="button" id="maxbt">max</button>
<button type="button" id="minbt">>min</button>
<button type="button" id="closebt">>close</button>
</div>
</section>
<script>
import {ipcRenderer, remote} from 'electron';
// 最小化
document.getElementById("minbt").addEventListener("click", function (e) {
var win = remote.getCurrentWindow();
win.minimize();
});
// 最大化或者還原
document.getElementById("maxbt").addEventListener("click", function (e) {
var win = remote.getCurrentWindow();
if (!win.isMaximized()) {
win.maximize();
} else {
win.unmaximize();
}
});
// 結束窗口
document.getElementById("closebt").addEventListener("click", function (e) {
var win = remote.getCurrentWindow();
win.close();
});
// 設置是否最大化和還原:
ipcRenderer.on('setMaxReset', (event, arg) => { // 接收到Main進程返回的消息
if(arg) { // 最大化了,設置還原樣式
}else { // 還原了,設置最大化樣式
}
})
// 阻止外面文件拖拽到導航欄,進行打開了
function dragover(e) {
e.stopPropagation();
e.preventDefault();
}
function drop(e)?{
e.stopPropagation();
e.preventDefault();
}
</script>
<style>
#kw {
/* 去除拖拽 */
-webkit-app-region: drag;
/* 禁止選中文本 */
-webkit-user-select: none;
}
.noDrag {
/* 下面這句話加不加都可以 */
-webkit-app-region: no-drag;
}
</style>
```
> 主程序
```
// 監聽最大化事件
mainWindow.on('maximize', function () {
// 發給視圖
mainWindow.webContents.send('setMaxReset', true);
})
// 監聽還原
mainWindow.on('unmaximize', function () {
// 發給視圖
mainWindow.webContents.send('setMaxReset', false);
})
```
### 禁止系統刷新
> 我們在開發的時候,是有f5或者 ctrl + r 進行刷新。正式環境的話,一版都不會刷新。在ready-to-show生命周期內進行禁止按鍵
```js
/*找到主程序的index.js*/
mainWindow.on('ready-to-show', function () {
if(process.env.NODE_ENV === 'production') {
// 禁止默認快捷鍵
globalShortcut.register('F5', () => {
console.log('你按了f5');
// Do stuff when Y and either Command/Control is pressed.
})
globalShortcut.register('ctrl+r', () => {
console.log('你按了ctrl+r');
// Do stuff when Y and either Command/Control is pressed.
})
// 顯示窗口
}
})
```
- 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轉圖片
- 日歷