目錄
1.技术需求
2.应用说明
2.代码说明
3.总结
首頁 web前端 html教學 快速将网页版简书打造成具有个人特色的简书桌面应用_html/css_WEB-ITnose

快速将网页版简书打造成具有个人特色的简书桌面应用_html/css_WEB-ITnose

Jun 21, 2016 am 08:55 AM

近日对谷歌扩展以及应用很感兴趣,于是研究了下官方文档,特写此文记录一下,若有错误,敬请指教,如需转载,请说明出处。

1.技术需求

怎么用html css javascript这些前端技术来编写一个桌面应用,说到这,不得不说谷歌浏览器这款伟大的产品,其自行开发的V8引擎大大提升了javascript在chrome中的执行效率,甚至可以将谷歌浏览器想象成一个操作系统,而chrome app则是运行在其上的应用。chrome app开发十分迅速,是一个非常好玩的技术,下面就以网页版的简书为例子,快速将其打造成一个桌面应用,而且还是兼容的呢。

文档以及书籍参考: 官方文档:chrome apps about_apps参考书籍:Chrome扩展及应用开发

利用谷歌直接将一个网页打造成桌面应用实现起来可谓十分轻松,开发者只需要掌握html css javascript前端技术,再结合官方文档,基本上都能快速掌握。所以,只要你有基本的html css javascript技术,就可以很快的开发出有自己特色的简述桌面应用。反之,请去百度之,很快就可以基本掌握。对于本篇文章的目的:快速将网页版简书打造成桌面应用,只需要掌握Webview Tag,便可完成简书的桌面应用。在进行代码层次的说明之前,先上一张完成后的效果图:

2016-02-20 19:22:14 .png

2.应用说明

在编写应用之前,请容我先解释一下chrome app应该包含哪些文件,其由以下部分组成。

  • manifest文件将应用的一些信息提供给Chrome:这个应用是?它怎么运行?需要哪些额外的权限?
  • background script用来创建一个事件页面然后可靠地管理软件生命周期
  • 所有代码必须包含在chrome app的包内,其中包含html css js以及Native Client模块。
  • 所有icons和其他有利资源最好也包括在包里面
  • 说明:若想深入了解,可以去看官方文档:chrome apps first_app

知道了这些后,我们就可以看一下代码的目录结构,进行了解,具体再一一说明:

2016-03-05 23:05:43.png

2.代码说明

可以看到图中分别有css/ images/ js/文件夹以及main.html manifest.json文件,不过最主要的是manifest.json main.html background.js这三个文件,下面的叙述也是围绕这三个文件来做讲解。2.1.manifest.jsonmanifest.json文件的作用在上面的应用说明中已经解释得很清楚,其实不仅仅是chrome app,谷歌扩展也需要一个json格式的manifest,所以manifest.json文件很重要。代码如下所示:

{    "app":{        "background":{            "scripts":["js/background.js"]        }    },    "manifest_version":2,    "name":"简书",    "version":"0.1.0",    "description":"谷歌应用版的简书,对网页版本作出一些优化#__#,添加到桌面方便启动.",    "icons": {         "16": "images/ico_16.png",        "48": "images/ico_48.png",        "128": "images/ico_128.png"     },        //权限    "permissions":[//这里需要简书网页域名的权限以及webview调用简书页面显示到新窗口        "http://www.jianshu.com/*",        "webview"    ]}
登入後複製

上面字段意思表达地很清楚,我们来看看:

app              //Event Page会监听onLaunched事件,随即创建窗口,应用介绍有说这个作用,这里意思是app下面的background域会通过js/background.js创建窗口。manifest_version //整数表示文件自身格式的版本号,按照这个写就好了name             //应用名称version          //版本号其他都是某字段对应的意思,这里不一一解释
登入後複製

如果你想更加详细地了解,我不会说360全部都翻译了谷歌的官方文档,请移步manifest详细说明。2.2.main.html定义好manifest.json文件之后,现在浏览器知道了我们的应用叫什么,怎么运行的,需要的权限。那么,应用启动后,应用会通过Event Page监听onLaunched事件,然后创建一个窗口,那么窗口显示什么界面呢?这个界面就是main.html文件。这个界面主要看开发者的心情,想怎么写就怎么写,但是不要忘了引入background.js文件,其作用下面再说。代码如下所示:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>简书桌面版</title>    <link rel="stylesheet" type="text/css" href="css/main.css">    <script type="text/javascript" src="js/control.js"></script></head><body>    <div id="title_bar">简书--找回文字的力量        <a id="close"></a>        <a id="minimize"></a>    </div>    <webview id="web_content"></webview></body></html>
登入後複製

main.html文件里面的代码结构十分简单,这个界面可以分为三个部分,标题、控制按钮(关闭以及最小化)、webview显示的主体内容部分,当该窗口显示之后,若想对窗口进行样式上的修改,可以加一个 css文件,我这里是这样定义的:

//添加边框body{    margin: 0;    padding: 0;    border: #EEE 1px solid;}//标题栏部分样式#title_bar{    -webkit-app-region:drag;        //作用是让鼠标可以拖动窗口界面    height: 26px;    line-height: 26px;    font-size: 15px;    background-color: #EEE;    padding: 0 10px;    box-sizing: border-box;}//控制图标样式#title_bar a{    position: relative;    -webkit-app-region:no-drag;    //让控制图标可以被点击    display: inline-block;    float: right;    height: 14px;    width: 14px;    margin: 6px;    border: gray 1px solid;    box-sizing: border-box;    border-radius: 7px;}#close:hover{    background-color: #cf4646;}#minimize:hover{    background-color: #46B6CF;}/** * show content * 这定义webview调用简书网页页面后宽高的定义 */#web_content{    width: 100%;    height: 614px;}
登入後複製

好了,窗口的样式大概写出来了,下面要做的就是怎么将这个页面作为窗口显示出来,这就要看background.js文件了。2.3.background.js简单来说,background.js会指定应用启动是创建的窗口,上代码:

//Event Page监听onLaunched事件chrome.app.runtime.onLaunched.addListener(function(){    var screenWidth = screen.availWidth;    var screenHeight = screen.availHeight;    var width = 1200;    var height = 640;    var main_window = chrome.app.window.get('main');    if (main_window) {        main_window.show();    }else{        //这里就创建了一个id是main的新窗口,窗口内容是main.html            chrome.app.window.create("main.html",{            id:'main',            bounds:{                width:width,                height:height,                left: Math.round((screenWidth-width)/2),                top:  Math.round((screenHeight-height)/2)            },            minHeight: height,            minWidth:  width,            maxHeight: height,            maxWidth:  width,            frame: 'none'//不显示标题栏目,因为我们自己有写标题样式,不用使用默认的。        });    }});
登入後複製

通过注释就会明白这段代码的意思,现在,我们的应用就已经创建完成了,我们可以看看界面是什么样子了。不过在这之前,我们先要将应用加载到谷歌浏览器中,请打开谷歌浏览器,地址栏输入chrome://extensions/,打开开发者模式,点击加载已解压的扩展程序...,最后加载你创建的应用包,加载成功后如下所示:

jianshu.png

点击启动后,请看:

2016-03-06 12:07:14.png

main.html很好地显示出来了,其中标题(简书--找回文字的力量),两个控制按钮,中间一大快空白部分(空白部分是即将显示的主题内容)都是我们刚才定义的。现在我们就差最后一步就可以完成这个简书桌面应用了,就是利用Webview Tag调用简书网页页面,将其显示在main.html的中,我将具体代码写在了js/control.js中,如下:

//webwiew methodswindow.onload = function(){    var web_content = document.getElementById('web_content');    web_content.src="http://www.jianshu.com/";//定义获取的网页页面//在应用显示之前加载以下文件,但是应用加载出来后,在应用里面某些界面还需要脚本,所以下面又增加了一个方法。    web_content.addContentScripts([        {        name: 'jianshu',        matches: ['http://*.jianshu.com/*'],        css: { files: ['css/jianshu.css'] },        js: { files: ['js/jquery.1.11.3.min.js','js/jianshu.js'] },        run_at: 'document_start'    }]);//在每次页面加载后加入以下文件    web_content.addEventListener('loadcommit',    function(e) {        web_content.executeScript({ file: "js/jquery.1.11.3.min.js" });        web_content.executeScript({ file: "js/jianshu.js" });    });//控制按钮的方法,缩小以及关闭,还多写了一个最大化的方法,不过没有调用    var current_window = chrome.app.window.current();    document.getElementById('minimize').onclick = function(){        current_window.minimize();    }    document.getElementById('close').onclick = function(){        current_window.close();    }    document.getElementById('maximize').onclick = function(){        current_window.isMaximized()?current_window.restore():current_window.maximize();    }}
登入後複製

完成后界面是这样的:

2016-03-06 12:24:57.png

2.4.增加自己的特色到了这一步,恭喜你,你已经可以自己打造一个桌面应用了,到此,我们的简书桌面应用已经可以运行,我们现在要做的就是收尾工作,既然都已经将网页版本的简书都放进了我们的webview标签之中,那么我们为何不写一些自己想要的样式呢?在control.js文件中,我们分别引入了js/jquery.1.11.3.min.js js/jianshu.js css/jianshu.css文件,那么它们是干么的呢,这些文件可以在简书页面加载时候一同加载进去,让我来演示一下就明白了。比如说,在上面的图中左侧有个手机按钮来提示下载简书app,但是我已经下载了不想再看到,所以我可以写个js将其隐藏掉,将代码写在js/jianshu.js里,审查元素,知道其class是:ad-selector,所以可以这么写:

$(document).ready(function(){    $(".ad-selector").hide();  //将那个图标隐藏    $(".search-form").removeAttr('target');//不要target属性    $('a').removeAttr('target');})
登入後複製

我们可以来看看效果:

2016-03-06 12:25:48.png

怎么样,还不错吧,同样的,如果你对简书布局有什么想改动的地方,可以将css代码写在 css/jianshu.css中,好了,现在简书桌面应用已经打造完成了,只要将这个应用移动到你的桌面,就可以和使用其他应用一样使用了,而且兼容所有平台,当然前提是你得有谷歌浏览器。

3.总结

终于,我们将网页版简书打造成了桌面版,是不是非常方便,总结来看就是我们先定义 manifest.json文件,告诉浏览器我们编写的应用是什么,怎么启动什么的,然后再定义启动页面main.html,最后background.js将其作为窗口调用,这样一个桌面应用就完成了,如果要进行修改,可以利用webview进行引如css js文件,就如同js/control.js引入的js/jianshu.js css/jianshu.css文件,就是这样。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1318
25
PHP教程
1268
29
C# 教程
1248
24
了解HTML,CSS和JavaScript:初學者指南 了解HTML,CSS和JavaScript:初學者指南 Apr 12, 2025 am 12:02 AM

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

HTML:結構,CSS:樣式,JavaScript:行為 HTML:結構,CSS:樣式,JavaScript:行為 Apr 18, 2025 am 12:09 AM

HTML、CSS和JavaScript在Web開發中的作用分別是:1.HTML定義網頁結構,2.CSS控製網頁樣式,3.JavaScript添加動態行為。它們共同構建了現代網站的框架、美觀和交互性。

HTML,CSS和JavaScript的未來:網絡開發趨勢 HTML,CSS和JavaScript的未來:網絡開發趨勢 Apr 19, 2025 am 12:02 AM

HTML的未來趨勢是語義化和Web組件,CSS的未來趨勢是CSS-in-JS和CSSHoudini,JavaScript的未來趨勢是WebAssembly和Serverless。 1.HTML的語義化提高可訪問性和SEO效果,Web組件提升開發效率但需注意瀏覽器兼容性。 2.CSS-in-JS增強樣式管理靈活性但可能增大文件體積,CSSHoudini允許直接操作CSS渲染。 3.WebAssembly優化瀏覽器應用性能但學習曲線陡,Serverless簡化開發但需優化冷啟動問題。

HTML的未來:網絡設計的發展和趨勢 HTML的未來:網絡設計的發展和趨勢 Apr 17, 2025 am 12:12 AM

HTML的未來充滿了無限可能。 1)新功能和標準將包括更多的語義化標籤和WebComponents的普及。 2)網頁設計趨勢將繼續向響應式和無障礙設計發展。 3)性能優化將通過響應式圖片加載和延遲加載技術提升用戶體驗。

HTML與CSS vs. JavaScript:比較概述 HTML與CSS vs. JavaScript:比較概述 Apr 16, 2025 am 12:04 AM

HTML、CSS和JavaScript在網頁開發中的角色分別是:HTML負責內容結構,CSS負責樣式,JavaScript負責動態行為。 1.HTML通過標籤定義網頁結構和內容,確保語義化。 2.CSS通過選擇器和屬性控製網頁樣式,使其美觀易讀。 3.JavaScript通過腳本控製網頁行為,實現動態和交互功能。

HTML:建立網頁的結構 HTML:建立網頁的結構 Apr 14, 2025 am 12:14 AM

HTML是構建網頁結構的基石。 1.HTML定義內容結構和語義,使用、、等標籤。 2.提供語義化標記,如、、等,提升SEO效果。 3.通過標籤實現用戶交互,需注意表單驗證。 4.使用、等高級元素結合JavaScript實現動態效果。 5.常見錯誤包括標籤未閉合和屬性值未加引號,需使用驗證工具。 6.優化策略包括減少HTTP請求、壓縮HTML、使用語義化標籤等。

HTML的角色:構建Web內容 HTML的角色:構建Web內容 Apr 11, 2025 am 12:12 AM

HTML的作用是通過標籤和屬性定義網頁的結構和內容。 1.HTML通過到、等標籤組織內容,使其易於閱讀和理解。 2.使用語義化標籤如、等增強可訪問性和SEO。 3.優化HTML代碼可以提高網頁加載速度和用戶體驗。

HTML:是編程語言還是其他? HTML:是編程語言還是其他? Apr 15, 2025 am 12:13 AM

HTMLISNOTAPROGRAMMENGUAGE; ITISAMARKUMARKUPLAGUAGE.1)htmlStructures andFormatSwebContentusingtags.2)itworkswithcsssforstylingandjavascript for Interactivity,增強WebevebDevelopment。

See all articles