### 启动白屏(和设置的窗口颜色一样的颜色)
> 原因:在窗口对象中设置颜色,启动程序是先显示窗口在加载,那么就看到了窗口设置的。
>解决方案:先进行隐藏窗口,当加载完成后,进行显示窗口即可
```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转图片
- 日历