C端-陪诊医疗

根据下图渲染路由:

#Main.vue
<template>
  <router-view/>

  <!-- 底部导航栏 -->
  <van-tabbar v-model="active">
  <van-tabbar-item 
      v-for="item in router.options.routes[0].children"
      :key="item.path"
      icon="item.meta.icon"
      :url="`#/${item.path}`">{{ item.meta.name }}</van-tabbar-item>
  <!-- <van-tabbar-item icon="search">标签</van-tabbar-item>
  <van-tabbar-item icon="friends-o">标签</van-tabbar-item>
  <van-tabbar-item icon="setting-o">标签</van-tabbar-item> -->
</van-tabbar>

</template>
<script setup>
import { onMounted, ref } from 'vue'
import { useRoute, useRouter } from 'vue-router'

const active=ref(0)
const router=useRouter()
const route=useRoute()
onMounted(()=>{
  console.log(router,'router')
  const data=router.options.routes[0]
  active.value=data.children.findIndex(item => '/'+ item.path === route.path)
})

</script>
<style scoped>

</style>

效果:

登录页面:

<template>
  <h1>用户登录</h1>

  <!-- 登录表单 -->
  <van-form @submit="onSubmit">
  <van-cell-group inset>
    <van-field
      v-model="username"
      name="用户名"
      label="用户名"
      placeholder="用户名"
      :rules="[{ required: true, message: '请填写用户名' }]"
    />
    <van-field
      v-model="form.password"
      type="password"
      name="密码"
      label="密码"
      placeholder="密码"
      :rules="[{ required: true, message: '请填写密码' }]"
    />
  </van-cell-group>
  <div class="btn">
    <van-button round block type="primary" native-type="submit" >
      提交
    </van-button>
  </div>
</van-form>

</template>

<script setup>
import { reactive } from "vue"

// 表单数据
const form = reactive({
  username:'',
  password:''
})
// 表单提交
const onSubmit =()=>{

}

</script>
<style lang="less" scoped>
h1 {
  text-align: center;
}
.btn {
  margin: 16px;
}
</style>

效果:

axios的二次封装:

#utils/request.js
import axios from "axios"
const instance = axios.create({
  baseURL: 'https:/v3pz.itndedu.com/v3pz',
  timeout: 10000,
  headers:{"terminal":"h-5"}
});

// 添加请求拦截器
instance.interceptors.request.use(function (config) {
  // 在发送请求之前做些什么
  const token=localStorage.getItem('h5-token') //请求头
  // 不需要添加token的api
  const whiteUrl=['login']
  if(token && !whiteUrl.includes(config.url)){
    config.headers['h-token']=token
  }

  return config;
}, function (error) {
  // 对请求错误做些什么
  return Promise.reject(error);
});

// // 添加响应拦截器
instance.interceptors.response.use(function (response) {
  // 对接口异常的数据,给用户提示
  if(response.data.code === -1){
    ElMessage.warning(response.data.message)
  }
  if(response.data.code === -2){
    localStorage.removeItem('h5-token')
    localStorage.removeItem('h5_userInfo')
    // 清除持久化信息v
    window.location.href=window.location.origin
  }
  // 2xx 范围内的状态码都会触发该函数。
  // 对响应数据做点什么
  return response;
}, function (error) {
  // 超出 2xx 范围的状态码都会触发该函数。
  // 对响应错误做点什么
  return Promise.reject(error);
});

export default instance

#api.index.js
import request from '../utils/request'
export default {
  login(data){
    return request.post('/login'.data)
  }
}

#main.js
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import api from './api'

const app=createApp(App)

// 在实例上绑定属性
app.config.globalProperties.$api=api
// 路由挂载
app.use(router)
app.mount('#app')

#login.vue
<template>
  <h1>用户登录</h1>

  <!-- 登录表单 -->
  <van-form @submit="onSubmit">
  <van-cell-group inset>
    <van-field
      v-model="form.username"
      name="用户名"
      label="用户名"
      placeholder="用户名"
      :rules="[{ required: true, message: '请填写用户名' }]"
    />
    <van-field
      v-model="form.password"
      type="password"
      name="密码"
      label="密码"
      placeholder="密码"
      :rules="[{ required: true, message: '请填写密码' }]"
    />
  </van-cell-group>
  <div class="btn">
    <van-button round block type="primary" native-type="submit" >
      提交
    </van-button>
  </div>
</van-form>

</template>

<script setup>
import { getCurrentInstance, reactive } from "vue"
import { useRouter } from "vue-router"

const router=useRouter()
// 获取当前vue实例
const { proxy } =getCurrentInstance()

// 表单数据
const form = reactive({
  username:'',
  password:''
})
// 表单提交
const onSubmit =async()=>{
  const {data}=await proxy.$api.login(form)
  if(data.code === 1000){
    localStorage.setItem('h5_token', data.data.token)
    localStorage.setItem('h5_userInfo',JSON.stringify(data.data.userInfo))
    router.push('/home')
  }

}

</script>
<style lang="less" scoped>
h1 {
  text-align: center;
}
.btn {
  margin: 16px;
}
</style>

 

<template>
  <div class="header">
    <div class="header-left">
      中部地区
      <van-icon name="arrow" />
    </div>
    <!-- 搜索框 -->
    <van-search v-model="searchValue" shape="round" 
       placeholder="请输入搜索关键词" />
  </div>
<!-- 轮播图 -->

<van-swipe class="my-swipe" :autoplay="3000" indicator-color="white">
  <van-swipe-item
    v-for="item in homeData.slides"
    :key="item.id">
    <van-image
      :src="item.pic_image_url"
/>
  </van-swipe-item>
</van-swipe>


</template>
<script setup>
import { getCurrentInstance, onMounted, reactive, ref } from 'vue'
const searchValue=ref('')

// 获取当前实例
const { proxy } = getCurrentInstance()
// 首页数据
const homeData = reactive({
  hospitals:[],
  nav2s:[],
  navs:[],
  now:'',
  slides:[]
})
onMounted(async()=>{
  const res =await proxy.$api.index()
  console.log(res,'res')
  // const {data}=await proxy.$api.index()
  // Object.assign(homeData,data.data)
  // console.log(homeData);
})

</script>
<style lang="less" scoped>
.header {
    display: flex;
    justify-content: space-between;
    margin: 5px;
    line-height: 54px;
    .header-left {
      padding-left: 22px;
      background: url()
        no-repeat left center;
      background-size: 20px;
      font-size: 20px;
      font-weight: bold;
      color: #666666;
    }
  }
  .my-swiper {
    margin: 5px;
  }
  .yy-list {
    padding-bottom: 10px;
    margin: 20px 0;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 1px 6px 0 rgba(0, 0, 0, 0.04), 0 1px 6px 0 rgba(0, 0, 0, 0.04);
    .yy {
      .yy-name {
        font-size: 20px;
        line-height: 30px;
        font-weight: bold;
      }
      .yy-type {
        font-weight: bold;
        line-height: 25px;
        font-size: 15px;
        color: #0ca7ae;
      }
      .yy-text {
        font-size: 14px;
        color: #999999;
      }
    }
  }
  .bottom-text {
    line-height: 50px;
    text-align: center;
    color: #999999;
  }
</style>

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值