小小千想和您聊一聊

当前位置: 首页> 技术分享> Electron使用指南之添加一个新的信息

Electron使用指南之添加一个新的信息

1、创建 Store

1.1 编辑 store

编辑 /vue-renderer/src/store/index.js:

import Vue from 'vue'

import Vuex from 'vuex'

 

Vue.use(Vuex)

 

export default new Vuex.Store({

  state: {

    isShowModal: false

  },

 

  mutations: {

    setModalVisible(state, show) {

      state.isShowModal = show

    }

  },

 

  actions: {

    setModalVisible({commit}, show) {

      commit('setModalVisible', show)

    }

  }

})

1.2 引入 store

编辑 /vue-renderer/src/main.js:

// ...

import store from './store'

// ...

2、显示添加窗口

编辑 /vue-renderer/src/components/Header.vue:

<template>

  <header>

    <button id="show-modal" @click="setModalVisible(true)">+</button>

    // ...

  </header>

</template>

 

<script>

import { mapActions } from 'vuex'

export default {

  methods: {

    ...mapActions(['setModalVisible'])

  },

}

</script>

3、完善添加模态组件

编辑 /vue-renderer/src/components/Modal.vue:

<template>

  <div id="modal" v-show="isShowModal">

    <input type="text" id="url" :disabled="status" v-model="url" placeholder="输入 URL ...">

    <button id="add-item" :class="{disabled: status}" :disabled="status" @click="addItem">{{addButtonText}}</button>

    <button id="close-modal" v-show="!status" @click="setModalVisible(false)">取消</button>

  </div>

</template>

 

<script>

import { mapState, mapActions } from 'vuex'

 

export default {

  data() {

    return {

      url: '',

      status: false,

      addButtonText: '添加'

    }

  },

 

  created() {

 

    // Listen for new item from main process

    ipcRenderer.on('new-item-success', (e, newItem) => {

      console.log(newItem)

 

      this.status = false

      this.addButtonText = '添加'

      this.url = ''

 

      this.setModalVisible(false)

    })

  },

 

  computed: {

    ...mapState(['isShowModal'])

  },

 

  methods: {

    ...mapActions(['setModalVisible']),

 

    addItem() {

      if (this.url !== '') {

 

        // Send new item url to main process

        ipcRenderer.send('new-item', this.url)

 

        this.status = true

        this.addButtonText = '添加中...'

      }

    }

  }

}

</script>

4、完善主进程 main.js

编辑 /main.js , 在文件代码中的最外层添加 ipcMain 的 new-item 时间监听,重点是 ipc 通信:

//...

 

// Modules

const { ipcMain } = require('electron')

 

// Listen for new item request

ipcMain.on('new-item', (e, itemUrl) => {

 

  // Get new item and send back to renderer

  setTimeout(() => {

    e.sender.send('new-item-success', 'New item from main process')

  }, 2000)

})

 

// ...

上一篇:Electron使用指南之构建 Vue 项目基本结构

下一篇:Electron使用指南之获得屏幕快照

QQ技术交流群

HTML5/Web前端锋迷群
712051083

加入群聊

用户登录

手机号:

密码:

图形验证码:

点击切换

用户注册

手机号:

登录密码:

图形验证码:

点击切换

短信验证码:

获取验证码

忘记密码

1安全验证

2重置密码

手机号:

图形验证码:

短信验证码:

获取验证码

忘记密码

1安全验证

2重置密码

新密码:

确认新密码:

获取课程

添加小千老师微信,获取课程信息

如何获取课程?

一、需拥有此本教材

如没有,可点击下方入口购买当当购买入口京东购买入口

二、添加小千老师,发送拥有凭证,解锁课程资源

1.购买该教材的订单信息
2.拥有的实体书信息等

更换手机号

新手机号:

图形验证码:

短信验证码:

获取验证码