Electron/vue、vuex、element、axios and cordova等接触....

最近公司Android项目这边没太多事情,新版本也暂时没需要做开发。然后公司目前要做一个政府通的项目,给政府或者给内部人员使用。之前考虑的是Windows端,采用winform的形式做开发。一直有招人,也没招到合适的。我之前有接触过这块,当时跟领导说可以辅助。再到后来搬了一个新的办公地点,然后又考虑了下Teambition采用的方案,貌似就是Documentation | Electron这个东东。然后前端人员就看了看,说可以搞,说干就干。

1. 目前大概理解就是Documentation | Electron给html页面包了一层Windows的外壳,这个外壳作为主进程运行着,内部维护了一个渲染(render)进程用来渲染页面,然后主进程可以和渲染进程之间可以进行通讯。主进程可以进行一些托盘,电池、任务栏、省电、放大、缩小等一些事件的处理。如果有需要通知到渲染进程,比如某个页面需要收到系统通知消息,然后弹出提示,就可以托盘收到消息,然后通知给渲染进程,进而实现渲染进程的系统级通知。

  1. Electron又配合起步 · electron-vue来做开发,vue作为比较强大的JavaScript MVVM库,给前端开发带来了简单快速的开发方式。另外还可以配合脚手架快速搭建工程环境,快速进行开发、打包。

至于与其他的对比,网上很多说法,主要看公司如何选型。

https://blog.csdn.net/weixin_41879988/article/details/81638474

React、Angular和Vue三种最流行的前端框架哪一个最好?

3. 界面配合The world's most popular Vue UI framework Element可以满足大部分需求

4. 网络配合 axios中文文档|axios中文网 较容易进行网络请求封装处理

5. 状态存储可以配合开始 | Vuex 进行组件状态的管理(比如:登录后我们进行用户信息的存储,然后同时提供getters来获取用户登录token等信息用于进一步用户相关数据的请求;当然也可以配合localstorage做永久存储)

以上就是上周(2019.05.01之前的那周)跟前端开发人员一起搞了下环境的搭建和安装,基本上参考上面几个官方文档就行。有些问题遇到了就网上查了下,最后基本都解决了。一般搭建环境总会遇到一些问题的。小萌新本来只是打算搞Android以及跨平台方面的,比如react-navtive、weex、flutter其中一个的。但领导安排一起搞,那就一起搞搞,说不定后面做跨平台App有所帮助了。

image

o_o. 这里还有几篇关于移动跨平台框架对比和感受建议的文章:

https://blog.csdn.net/sl_40/article/details/79637320

Flutter将会秒杀RN?行业高手为你细细道来-紫金网

https://blog.csdn.net/makercloud/article/details/81560987

angular、react、vue 三大前端框架适用场景

国内有哪些用angular做的比较好的移动端webapp_百度知道

html + css麻烦熟悉一下,O(∩_∩)O哈哈~

angular - 适合大型项目/PC,移动端据说性能不是很好,第二个版本好像移动优先。不过案例不太多

Vue相对轻,容易上手,需要配合Cordova来与原生交互打包

Weex,阿里的,基于Vue.js来的,相对来讲还得看发展,目前纳入Apache孵化,期待发展

React-navtive,Facebook据说准备重写,文档社区相对完善活跃,目前也是很多公司采用........需要熟悉Js的一些语法呀!

Flutter,闲鱼代表作,Google发展中,或许Fuchsia就是它了...需要学习Dart语言,上手有难度

个人感受,目前实用的话,React-navtive可能好些。未来趋势可能Flutter比较可以,毕竟有Google支持以及新系统的支持...谁知道呢? Vue目前用来开发桌面,或者一些小型应用貌似也还不错,做了直接转Weex貌似很直接。 angular目前来说移动端暂无考虑!

最后看自己如何考虑....

6. 既然协助前端搞Electron ,就顺便看看Vue如何配合Apache Cordova 进行Android的开发...至于其他细节如果用到该方式就可以抓紧干就完事了!

前面环境都搭建好了,基本上照着如下网友步骤没啥大问题

cordova+vue 项目打包成Android(apk)应用

image

接下来,就可以尝试进行Vue的开发了哟。html,css要熟悉的呀...不然写页面好慢呀....开发好了就可以打包成Android应用瞅瞅了....

可能路还很长,很长,这里小萌新记录下吧。小萌新也没那么多精力做那么多事情,只是遇到了就留个印象,也对跨平台开发做个了解嘛!

关于Vue小萌新也花了一天做了一个入门练习,html+css相关明天也练习哈吧,(#.#)

Vue.js 入门教程 | 菜鸟教程

vueapp.js

Vue.filter('reverses', function (value) {
    return value.split('').reverse().join('')
}),
// 2.0及以后要自己定义过滤器
Vue.filter('uppercase', function (value) {
    if (!value) { return ''}
    value = value.toString()
    return value.toUpperCase()
}),
new Vue({
    el: '#app',
    data: {
        message: '菜鸟呀菜鸟!',
        todos: [
            { text: 'Jsa' },
            { text: 'Jsb' },
            { text: 'JSc' }
        ]
    }
}),
new Vue({
    el: '#app2',
    data: {
        todos: [
            { text: 'JS' },
            { text: 'JS2' },
            { text: 'JS3' }
        ],
        bShow: true
    }
}),
// 接收保存,之后通过test.的方式操作内部变量等属性
test = new Vue({
    el: '#app3',
    data: {
        message3: 'Hello World!'
    }
}),
new Vue({
    el: '#appc',
    data: {
        msg: '你好鸭!',
        url: 'https://cn.bing.com'
    },
    methods: {
        say (msg) {
            alert(msg)
        },
        say2 () {
            alert(this.msg)
        }
    }
})

vueapp.html

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<div id="app">
    <p>{{ message }}</p>
    <p>{{'www.runoob.com' | reverses}}</p>
    <input v-model="message">
    <ul>
        <li v-for="todo in todos">
            {{ todo.text | uppercase }}
        </li>
    </ul>
</div>
<div id="app3">
    <p>{{ message3 }}</p>
    <input v-model="message3">
</div>
<div id="app2">
    <ul>
        <li v-for="todo in todos">
            {{ todo.text }}
        </li>
    </ul>
    <p v-if="2 > 1">2货</p>
    <h1 v-if="bShow">yes</h1>
    <h1 v-else>no</h1>
    <template v-if="bShow">
        <h1>我靠</h1>
    </template>
    <h1 v-show="!bShow" style="background:#000; color:#FFF">你看我</h1>
</div>
<div id="appc">
    <a v-on:click="say('Hi')">点击say</a>
    <a @click="say2">点击say2</a>

    <a href="http://www.baidu.com">百度</a>
    <a href="url">不用指令怎么解析呢?</a>
    <a v-bind:href="url">必应</a>
    <a :href="url">必应2</a>
</div>
<!-- JavaScript 外部单独js文件;代码需要放在尾部(指定的HTML元素之后) -->
<script src="vueapp.js"> 
</script>
<!-- 内置js方式 test接收保存 -->
<!-- <script>
    // var exampleData = {
    //     message3: 'Hello World!'
    // }
    test = new Vue({
        el: '#app3',
        data: {
            message3: 'Hello World!'
        }
    })
</script> -->
image
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容