Explorar el Código

添加路由,写设置页(具体配置项待写)

admincjy hace 3 años
padre
commit
f6791f76a5
Se han modificado 5 ficheros con 103 adiciones y 3 borrados
  1. 3 1
      src/App.vue
  2. 2 2
      src/components/Sidebar.vue
  3. 2 0
      src/main.js
  4. 83 0
      src/pages/settings/Settings.vue
  5. 13 0
      src/router/index.js

+ 3 - 1
src/App.vue

@@ -3,7 +3,9 @@
     <el-container>
       <!-- todo: bug fix 侧边栏线为什么不延长到底 -->
       <el-aside><Sidebar></Sidebar></el-aside>
-      <el-main></el-main>
+      <el-main>
+        <router-view></router-view>
+      </el-main>
     </el-container>
   </div>
 </template>

+ 2 - 2
src/components/Sidebar.vue

@@ -1,7 +1,7 @@
 <template>
   <el-row class="tac">
   <el-col style="width: 150px">
-    <el-menu class="el-menu-vertical-demo">
+    <el-menu class="el-menu-vertical-demo" :router="true">
       <!-- todo: 图标 -->
       <el-menu-item index="2">
         <i class="el-icon-menu"></i>
@@ -19,7 +19,7 @@
         <i class="el-icon-s-opportunity"></i>
         <span slot="title">信号</span>
       </el-menu-item>
-      <el-menu-item index="5">
+      <el-menu-item index="/settings">
         <i class="el-icon-s-tools"></i>
         <span slot="title">设置</span>
       </el-menu-item>

+ 2 - 0
src/main.js

@@ -1,6 +1,7 @@
 import Vue from 'vue'
 import ElementUI from 'element-ui';
 import 'element-ui/lib/theme-chalk/index.css';
+import router from "./router"
 import App from './App.vue'
 
 Vue.config.productionTip = false
@@ -8,6 +9,7 @@ Vue.config.productionTip = false
 Vue.use(ElementUI);
  
 new Vue({
+  router,
   render: h => h(App),
 }).$mount('#app')
 

+ 83 - 0
src/pages/settings/Settings.vue

@@ -0,0 +1,83 @@
+<template>
+  <el-form ref="form" :model="form" label-width="80px">
+    <el-form-item label="活动名称">
+      <el-input v-model="form.name"></el-input>
+    </el-form-item>
+    <el-form-item label="活动区域">
+      <el-select v-model="form.region" placeholder="请选择活动区域">
+        <el-option label="区域一" value="shanghai"></el-option>
+        <el-option label="区域二" value="beijing"></el-option>
+      </el-select>
+    </el-form-item>
+    <el-form-item label="活动时间">
+      <el-col :span="11">
+        <el-date-picker
+          type="date"
+          placeholder="选择日期"
+          v-model="form.date1"
+          style="width: 100%"
+        ></el-date-picker>
+      </el-col>
+      <el-col class="line" :span="2">-</el-col>
+      <el-col :span="11">
+        <el-time-picker
+          placeholder="选择时间"
+          v-model="form.date2"
+          style="width: 100%"
+        ></el-time-picker>
+      </el-col>
+    </el-form-item>
+    <el-form-item label="即时配送">
+      <el-switch v-model="form.delivery"></el-switch>
+    </el-form-item>
+    <el-form-item label="活动性质">
+      <el-checkbox-group v-model="form.type">
+        <el-checkbox label="美食/餐厅线上活动" name="type"></el-checkbox>
+        <el-checkbox label="地推活动" name="type"></el-checkbox>
+        <el-checkbox label="线下主题活动" name="type"></el-checkbox>
+        <el-checkbox label="单纯品牌曝光" name="type"></el-checkbox>
+      </el-checkbox-group>
+    </el-form-item>
+    <el-form-item label="特殊资源">
+      <el-radio-group v-model="form.resource">
+        <el-radio label="线上品牌商赞助"></el-radio>
+        <el-radio label="线下场地免费"></el-radio>
+      </el-radio-group>
+    </el-form-item>
+    <el-form-item label="活动形式">
+      <el-input type="textarea" v-model="form.desc"></el-input>
+    </el-form-item>
+    <el-form-item>
+      <el-button type="primary" @click="onSubmit">立即创建</el-button>
+      <el-button>取消</el-button>
+    </el-form-item>
+  </el-form>
+</template>
+
+<script>
+export default {
+  name: "Settings",
+  data() {
+    return {
+      form: {
+        name: "testxxxx",
+        region: "",
+        date1: "",
+        date2: "",
+        delivery: false,
+        type: [],
+        resource: "",
+        desc: "",
+      },
+    };
+  },
+  methods: {
+    onSubmit() {
+      console.log("submit!");
+    },
+  },
+};
+</script>
+
+<style>
+</style>

+ 13 - 0
src/router/index.js

@@ -0,0 +1,13 @@
+import Vue from "vue";
+import VueRouter from "vue-router";
+
+Vue.use(VueRouter)
+
+export default new VueRouter({
+    routes: [
+        {
+            path: '/settings',
+            component: ()=>import('@/pages/settings/Settings.vue')
+        }
+    ]
+})