## 獲取多個屏幕信息 示例
```
//獲取屏幕信息
Display_Detection(null,e=>{console.log(e)})
//指定分辨率獲取
Display_Detection([1920,1080,1024,500,1440,1050,1600,1024],e=>{console.log(e)})
```
## 參數
函數:`Display_Detection`
參數:
* 參數1 ResolvingPower?非必填?可傳入分辨率數組?完成自定義屏幕檢測?【基數是寬,偶數是高】
* 參數2 callback?必填?回調
返回結果:
* 數字下標結果解釋 0屏幕數量、1總屏幕尺寸、2主屏幕尺寸、3副屏尺寸
## 使用與注意
* 如果僅有主屏幕時或有異常時2,3下標值都為0
* 實現不同屏幕顯示不同窗口??必須注意?將屏幕設置為【擴展顯示】
* 目前僅支持的分辨率:1024,500,1440,1050,1600,1024,1600,900,1680,1050,1280,1024,1024,768,800,600,1440,900,1024,600,1280,800,1280,?720,1366,768,?1920,?1080,?2560,?1440,?3840,?2160,?4096,?2160,?7680,?4320 如果沒有可用的分辨率可自行指定分辨率

## 設置窗口到其他屏幕中【副屏設置】
函數:`setPositionWin`
作用:
* 設置當前窗口位置與標題并自動最大化
* 默認最大化 可再次執行會進行放大縮小窗口
## 使用示例
* 結合以上獲取屏幕坐標實現
示例如下:
```
//采用html字符串寫入方式加載頁面、使用變量共享方式變量互相共享(可使用數據雙向綁定實現實時更新數據)
//啟動一個窗口
pageOpener = window.open();
//測試變量在新窗口訪問
window.page1 = 100
//載入內容 采用寫入方式 也可以http方式
pageOpener.document.write(`
<body style="background: #fff;">
<h1>好嗨哦</h1>
</body>
<script>
//設置子窗口值
window.page2 = 200
//獲取父類窗口的值
console.log(window.opener.page1)
//檢測可用函數 避免異步創建導致函數失效
var okFunc = 0;
//用到的函數
var funcList = ['Display_Detection','setPositionWin'];
function testing(){
okFunc = 0;
funcList.forEach((item)=>{
if(window[item] !== undefined){
okFunc+=1;
}
})
console.log(okFunc,funcList.length)
if(okFunc != funcList.length){
okFunc = 0;
timeout()
}else{
startFunc();
}
}
function timeout(){
setTimeout(()=>{
testing()
},500)
}
testing()
function startFunc(){
//獲取屏幕
let x=0;
let y=0;
//設置屏幕
window.Display_Detection(null,e=>{
x=e.data[2][0];
y=e.data[2][1];
//設置屏幕
window.setPositionWin('客顯副屏',x,0,600,600,e=>{console.log(e)})
})
}
</script>
`)
//獲取子窗口的值
console.log(pageOpener.window.page2)
//5s后自動關閉副屏
setTimeout(() => {
pageOpener.close()
}, 5000);
```
* 對于更多的頁面加載方式或窗口通訊方式請看下面
## 窗口內容加載
* 1.通過http形式加載
* 2.通過opener對象來進行文檔內容設置
* 3.使用`open("data:text/html,<h1>123456</h1>");`
## 窗口間通信
* 1.postMessage
* 2.window變量共享進行變量監控(雙向綁定)
* 3.如果使用vuex等類似狀態管理,可以考慮實現vue沙箱模式等類似其他框架也可以這么考慮。或者嘗試在子窗口掛載父窗口里的部分環境數據,比較靈活,自己嘗試。完全可實現父子窗口用一個狀態管理。只是新窗口里的環境可能需要自己掛載進去。比如將vue沙箱掛載進去等
- 簡介
- 系統變量
- Ext核心對象
- 調用php對數組js升序排序
- 獲取并格式化當前時間
- md5加密
- 輸出php所有定義函數
- 多參數傳遞
- 數據庫
- 介紹
- 原生sql
- 抽象層
- 抽象層-增加數據
- 抽象層-刪除數據
- 抽象層-更新數據
- 抽象層-查詢單條數據
- 抽象層-查詢結果集
- 電子秤
- 大華條碼電子秤-本地預打包條碼專用與PLU
- 大華電子秤-PLU導入
- ip電子秤
- 一體機稱重稱(串口電子秤)
- 大華電子秤-掃描
- 大華電子秤-初始化配置
- PLU文件導入
- 串口稱或串口地磅稱
- 大華電子秤基本操作
- 托利多PC一體稱臺秤
- 通知欄
- 窗口操作
- 打印機
- 切紙
- 固定模板打印
- html模板打印
- 對照表
- html打印
- web打印控件
- 建議打印機
- 收銀掃碼
- pos機發起收款
- API發起收銀
- 系統配置
- 播放聲音
- 注意事項
- 鍵盤監聽
- 實體會員卡
- 錢箱
- 全屏顯示
- 串口
- 硬件
- 客顯
- browser對象
- 相關知識
- 區位碼
- 相關硬件
- 掃碼槍
- 副屏