基于vue3的仿写cnodejs.org社区的webapp

  1. 本项目用vue3实现,自定义plugin的alert和toast编写, vuex全局管理用户状态信息

在这里插入图片描述

demo

demo 访问
源码地址

vue3 的文档

文档入口

github地址

源码地址入口

部分代码

<script>
import { ref, reactive, toRefs, computed } from "vue";
import { useRouter } from "vue-router";
import { useStore } from "vuex";

export default {
  name: "index",
  components: {  },
  setup() {
    // router 对象
    const router = useRouter();

    const tab = ref("all");
    // console.info(tab.value)
   
    const datalist = reactive({ list: [] });
    // console.info(datalist.list)

    const userId = ref(0)
    userId.value = computed(() => store.state.id || 0).value;


    // 请求接口
    const useListEffect = async () => {
      const result = await get(
        `/topics?page=${page.value}&tab=${tab.value}&limit=20`
      );
      if (result?.success && result?.data?.length) {
        datalist.list = [...datalist.list, ...result.data];
      }
    };

    // 跳转页面
    const goDetail = ({ id }) => {
      router.push(`/detail?id=${id}`);
    };

    useListEffect();

    return {
      tab,
      ...toRefs(datalist),
      goDetail,
      userId
    };
  },
};
</script>

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值