index.vue 3.76 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12
<template>
  <div class="add">
    <div class="add-tab">
      <el-tabs v-model="activeName" :stretc="true">
        <el-tab-pane
          v-for="item in tabs"
          :key="item.key"
          :label="item.label"
          :name="item.key"
        />
      </el-tabs>
    </div>
13 14 15 16 17 18 19 20 21 22
    <div class="content">
      <div class="content-title">添加铁路信息</div>
      <el-form
        ref="form"
        :model="formData"
        :rules="rules"
        label-width="200px"
        class="form"
      >
        <el-form-item label="铁路名:" prop="name">
23 24
          <el-input v-model="formData.name" placeholder="请输入铁路名" />
        </el-form-item>
25 26 27 28 29
        <el-form-item label="铁路线起点站名:" prop="start">
          <el-input
            v-model="formData.start"
            placeholder="请输入铁路线起点站名:"
          />
30
        </el-form-item>
31
        <el-form-item label="铁路线终点站名:" prop="end">
32 33
          <el-input v-model="formData.end" placeholder="请输入铁路线终点站名" />
        </el-form-item>
34 35 36 37 38
        <el-form-item label="铁路全长(公里):" prop="long">
          <el-input
            v-model="formData.long"
            placeholder="请输入铁路全长公里数"
          />
39 40
        </el-form-item>
      </el-form>
41 42 43 44
    </div>
    <div class="btn">
      <el-button type="primary" @click="reset">重置</el-button>
      <el-button type="primary" @click="submit">确认提交</el-button>
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      activeName: '0',
      tabs: [
        {
          label: '铁路线',
          key: '0'
        },
        {
          label: '站点',
          key: '1'
        },
        {
          label: 'FSU',
          key: '2'
        },
        {
neogcg's avatar
neogcg committed
68
          label: '监测设备',
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121
          key: '3'
        },
        {
          label: '漏缆',
          key: '4'
        },
        {
          label: '天馈线',
          key: '5'
        }
      ],
      formData: {
        name: '',
        start: '',
        end: '',
        long: ''
      },
      rules: {
        name: [
          { required: true, message: '请输入铁路名', trigger: 'blur' }
          // { min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }
        ],
        start: [
          { required: true, message: '请输入铁路线起点站名', trigger: 'blur' }
        ],
        end: [
          { required: true, message: '请输入铁路线终点站名', trigger: 'blur' }
        ],
        long: [
          { required: true, message: '请输入铁路全长公里数', trigger: 'blur' }
        ]
      }
    }
  },
  methods: {
    reset() {
      this.$refs.form.resetFields()
    },
    submit() {
      this.$refs.form.validate((valid) => {
        if (valid) {
          console.log(this.formData)
        }
      })
    }
  }
}
</script>

<style lang="scss" scoped>
::v-deep .el-tabs__nav {
  display: flex;
  width: 100%;
122
  padding-bottom: 10px;
123 124 125
  .el-tabs__item {
    flex: 1;
    text-align: center;
126 127 128 129 130 131 132 133
    font-size: 18px;
    color: #666;
  }
  .el-tabs__item.is-active {
    color: #1e64f6;
  }
  .el-tabs__active-bar {
    background-color: #1e64f6;
134 135
  }
}
136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160
.add {
  padding: 10px;
  .tab {
    // width: 600px;
    margin: 0 auto;
  }
  .content {
    border: 1px solid #e3e3e3;
    border-radius: 10px;
    .content-title {
      width: 100%;
      height: 60px;
      background: rgba(226, 235, 255, 0.39);
      line-height: 60px;
      font-size: 18px;
      color: #333;
      font-weight: 500;
      text-align: center;
      border-bottom: 1px solid #e3e3e3;
    }
    .form {
      padding: 20px 0;
      width: 600px;
      margin: 0 auto;
    }
161
  }
162 163 164 165 166 167
  .btn {
    padding-top: 50px;
    text-align: center;
    button {
      width: 120px;
    }
168 169 170
  }
}
</style>