목차
1.技术需求
2.应用说明
2.代码说明
3.总结
웹 프론트엔드 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 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

& lt; Progress & Gt의 목적은 무엇입니까? 요소? & lt; Progress & Gt의 목적은 무엇입니까? 요소? Mar 21, 2025 pm 12:34 PM

이 기사는 HTML & lt; Progress & Gt에 대해 설명합니다. 요소, 그 목적, 스타일 및 & lt; meter & gt의 차이; 요소. 주요 초점은 & lt; progress & gt; 작업 완료 및 & lt; meter & gt; Stati의 경우

& lt; datalist & gt의 목적은 무엇입니까? 요소? & lt; datalist & gt의 목적은 무엇입니까? 요소? Mar 21, 2025 pm 12:33 PM

이 기사는 HTML & LT; Datalist & GT에 대해 논의합니다. 자동 완성 제안을 제공하고, 사용자 경험을 향상시키고, 오류를 줄임으로써 양식을 향상시키는 요소. 문자 수 : 159

HTML5의 크로스 브라우저 호환성에 대한 모범 사례는 무엇입니까? HTML5의 크로스 브라우저 호환성에 대한 모범 사례는 무엇입니까? Mar 17, 2025 pm 12:20 PM

기사는 HTML5 크로스 브라우저 호환성을 보장하기위한 모범 사례에 대해 논의하고 기능 감지, 점진적 향상 및 테스트 방법에 중점을 둡니다.

& lt; meter & gt의 목적은 무엇입니까? 요소? & lt; meter & gt의 목적은 무엇입니까? 요소? Mar 21, 2025 pm 12:35 PM

이 기사는 HTML & lt; meter & gt에 대해 설명합니다. 범위 내에 스칼라 또는 분수 값을 표시하는 데 사용되는 요소 및 웹 개발의 일반적인 응용 프로그램. & lt; meter & gt; & lt; Progress & Gt; 그리고 Ex

HTML5 양식 유효성 검사 속성을 사용하여 사용자 입력을 유효성있게하려면 어떻게합니까? HTML5 양식 유효성 검사 속성을 사용하여 사용자 입력을 유효성있게하려면 어떻게합니까? Mar 17, 2025 pm 12:27 PM

이 기사에서는 브라우저에서 직접 사용자 입력을 검증하기 위해 필요한, Pattern, Min, Max 및 Length 한계와 같은 HTML5 양식 검증 속성을 사용하는 것에 대해 설명합니다.

html5 & lt; time & gt; 의미 적으로 날짜와 시간을 나타내는 요소? html5 & lt; time & gt; 의미 적으로 날짜와 시간을 나타내는 요소? Mar 12, 2025 pm 04:05 PM

이 기사는 html5 & lt; time & gt; 시맨틱 날짜/시간 표현 요소. 인간이 읽을 수있는 텍스트와 함께 기계 가독성 (ISO 8601 형식)에 대한 DateTime 속성의 중요성을 강조하여 Accessibilit를 향상시킵니다.

뷰포트 메타 태그는 무엇입니까? 반응 형 디자인에 중요한 이유는 무엇입니까? 뷰포트 메타 태그는 무엇입니까? 반응 형 디자인에 중요한 이유는 무엇입니까? Mar 20, 2025 pm 05:56 PM

이 기사는 모바일 장치의 반응 형 웹 디자인에 필수적인 Viewport Meta Tag에 대해 설명합니다. 적절한 사용이 최적의 컨텐츠 스케일링 및 사용자 상호 작용을 보장하는 방법을 설명하는 반면, 오용은 설계 및 접근성 문제로 이어질 수 있습니다.

& lt; iframe & gt; 꼬리표? 보안을 사용할 때 보안 고려 사항은 무엇입니까? & lt; iframe & gt; 꼬리표? 보안을 사용할 때 보안 고려 사항은 무엇입니까? Mar 20, 2025 pm 06:05 PM

이 기사는 & lt; iframe & gt; 외부 컨텐츠를 웹 페이지, 공통 용도, 보안 위험 및 객체 태그 및 API와 같은 대안을 포함시키는 태그의 목적.

See all articles