node-webkit学习之【无边框窗口用JS实现拖动改变大小等】
效果如下图

原生的如下图(原生的用在自己的app上面太丑了,并且还带边框,所以重写了左上角的三个功能键)

1.首先了解一下nw底下的package.json 文件
{
"name": "nw-quick-start-demo", //(字符串)包的名字,必须为独一无二的,可由字母,数字,下划线组成,不能有空格。(
"version": "0.0.1",
"main": "app/test/dist/index.html",//字符串)当node-webkit打开时的默认页面。
"single-instance":false,
"node.js": true, //(布尔型)nodejs是否node-webkit中启用。
"window": { //控制窗口的样子
"icon": "app/images/logo.png", //(字符串)图标的路径。
"toolbar": true, //(布尔值)是否显示工具栏。
"title": "zm", //(字符串)默认打开的窗口的名字。
"resizable":true, //(字符串)只可能是这么几个值null center mouse。null指无定位,center指在显示器中间,mouse指在鼠标的位置。
"show_in_taskbar":true, //(布尔值)是否在任务栏上显示。
"position": "center",
"frame": false, //(布尔值)是否显示窗口框架。
"width": 430, //定义窗口的宽高
"height": 350,
"resizable":false //(布尔值)窗口是否可调整大小。
},
"webkit": { //控制webkit特性是否启用
"plugin": true
},
"dependencies": {
"vue-router": "^2.3.0"
}
}
2.无窗口模式下实现可以拖拽
如果frame 为false的话。程序将无边框显示。无边框显示则无法执行拖拽等功能。
可以设置以下代码让窗口可以拖拽
body
{
-webkit-user-select:none;
-webkit-app-region:drag;
}
但是统一在body加上这个样式的话可以拖拽了,但是所有点击等事件都会失去焦点了。
解决方法:就是在头部header元素加上可以拖拽样式。但是header里面的按钮等带有事件的元素加上样式【-webkit-app-region:no-drag;】让带有事件的元素可以点击。
3.无窗口模式下实现窗口最大化最小化关闭等 窗口功能键
html代码写好样式(项目中使用vue和ES6 所以事件的调用方法是用vue的)
<div id="toolBtns" class="noDrag" @click="focusWindow()"> //功能键上必须加上不可以拖拽样式,不然点击没有反应
<a href="javascript:;" class="noDrag" @click="miniWindow()"><i id="minisizeBtn"></i></a>
<a href="javascript:;" class="noDrag mr-10 ml-10" @click="resizeWindow()"><i id="resizeBtn"></i> </a>
<a href="javascript:;" class="noDrag" @click="closeWindow()"><i id="closeBtn"></i> </a> </div>
js实现
//node-webkit带有丰富的api,可以直接调用api来调整窗口
var gui = require('nw.gui'); //要访问api 首先需要先加载“nw.gui”模块
var win = gui.Window.get(); //需要将其功能添加到窗口 用get(),通过win.则可获取窗口对象
var flag=1;
console.log(gui);
win.on('resize', function () { //resize对象在窗体大小被重置时触发的事件。把标志放在resize中改变大小,
//目的是为了不让拖拽让窗口变大变小后影响 最大化最小化功能键的功能
if(flag==1) {
flag=0;
}else {
flag=1;
}
})
//功能键点击事件
miniWindow() { //实现窗口的最小化
win.minimize();
},
closeWindow() { //实现窗口的关闭
win.close();
},
resizeWindow() { //实现窗口的最大化最小化,通过全局的flag来控制不受拖拽影响
if(flag==1) {
//win.enterFullscreen();
win.maximize(); //窗口最大化事件。
}else {
win.restore(); //恢复窗口到上一状态。
}
},
注意:如果功能键事件没有写在启动文件里面时,加载“nw.gui”模块 依旧需要写在启动文件里面,不然获取不到!
附上nw.js的中文学习文档 https://wizardforcel.gitbooks.io/nwjs-doc/content/wiki/index.html共勉。
node-webkit学习之【无边框窗口用JS实现拖动改变大小等】的更多相关文章
- 【Qt编程】基于Qt的词典开发系列<四>--无边框窗口的缩放与拖动
在现在,绝大多数软件都向着简洁,时尚发展.就拿有道的单词本和我做的单词本来说,绝大多数用户肯定喜欢我所做的单词本(就单单界面,关于颜色搭配和布局问题,大家就不要在意了). 有道的单词本: 我所做的单词 ...
- PyQt4中无边框窗口的移动(拖动)
import sys from PyQt4.QtGui import * from PyQt4.Qt import * from PyQt4.QtCore import * class AboutUs ...
- node-webkit无边框窗口用纯JS实现拖动改变大小
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> & ...
- 【Qt编程】基于Qt的词典开发系列<五>--无边框窗口的拖动
在上一篇文章中,我们讲述了如何进行无边框窗口的缩放与拖动,而在一些情况下,我们的窗口只需要进行拖动也不需要改变其大小,比如:QQ的登录窗口.本来在上一篇文章中已经讲述了如何进行窗口的拖动,但是却与窗口 ...
- WPF系列:无边框窗口
<Window x:Class="Ares.Animations.Window3" xmlns="http://schemas.microsoft.com/winf ...
- 让Qt的无边框窗口支持拖拽、Aero Snap、窗口阴影等特性
环境:Desktop Qt 5.4.1 MSVC2013 32bit 需要的库:dwmapi.lib .user32.lib 需要头文件:<dwmapi.h> .<windowsx. ...
- Qt5:无边框窗口拖动
在窗口程序中,无边框窗口程序一般需要特殊处理才能拖动 Qt中,要实现无边框窗口的拖动,需要重新实现 mousePressEvent 和 mouseMoveEvent 俩虚函数 void Widget: ...
- [Winform]无边框窗口悬浮右下角并可以拖拽移动
摘要 简单实现了一个这样的功能,程序启动时,窗口悬固定在右下角,并可以通过鼠标拖拽移动. 核心代码块 无边框窗口并不出现在任务栏 //无边框 this.FormBorderStyle = System ...
- 【转】MFC 无边框窗口的拖动
MFC中无边框窗口的拖动 void CXXXXDialog::OnLButtonDown(UINT nFlags, CPoint point) { PostMessage(WM_NCLBUTTONDO ...
随机推荐
- Docker私有仓库--自签名方式
为了能集中管理我们创建好的镜像,方便部署服务,我们会创建私有的Docker仓库.通读了一遍官方文档,Docker为了确保安全使用TLS,需要CA认证,认证时间长的要钱啊,免费过期时间太短,还是用自签名 ...
- smarty模板做人员表信息删除,修改 里面的性别单选按钮民族下拉,另外登录进去可以显示姓名
首先登录进去可以显示姓名 smarty模板做人员表信息删除,删除的时候有提示框确定删除吗. 修改 里面的性别单选按钮,要修改谁有默认选中,用了变量调节器 民族位置做下拉,用<{foreach}& ...
- JS日期加减指定天数
JS中没有直接操作日期加减的方法,只能通过Date对象获取当前天数加减之后setDate,以此来达到操作日期的目的 JS中对指定日期加减指定天数,具体方法如下: function addDate(da ...
- BOM基础(四)
最近写的文章感觉内容不像之前那么充实,内容可能也有点杂.对于DOM,和BOM来说,要理解是不难的,难的是做的时候.要自己想的到,而且,对于目前阶段来说,BOM还存在着很大的兼容性问题,最主要就是要兼容 ...
- category类别中添加属性
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c91b13 } p.p2 { margin: 0.0px 0. ...
- 获取手机 id 与 ip
//id #import <AdSupport/AdSupport.h> //ip #include <ifaddrs.h> #include <arpa/inet.h& ...
- Android px、dp、sp之间相互转换 系统默认12 sp
px 就是像素 sp=dpX字体比例(1.25f) 一.dp(或者dip device independent pixels) 一种基于屏幕密度的抽象单位.在每英寸160点的显示器上,1dp=1px ...
- Socket协议
Socket协议的形象描述 socket的英文原义是"孔"或"插座".在这里作为4BDS UNIX的进程通信机制,取后一种意思.socket非常类似于电话插座. ...
- 用递归的方式处理数组 && 把递归方法方法定义到数组的原型上 (这是一次脑洞大开的神奇尝试)
在 javascript 里,如果我们想用一个函数处理数组 (Array) 中的每个元素,那我们有很多种选择,最简单的当然就是用自带的 forEach 函数(低版本也可以使用 lodash 中的 fo ...
- onchange、onclick、onblur等事件区别
onblur:控件在失去焦点的时候触发 OnChange:当控件的内容发生改变时触发该事件 OnClick:点击该控件时触发 OnKeyDown:在控件有焦点的情况下,按下键时发生 OnKeyUp:在 ...