实习手记(2):前端菜鸟的摸鱼与成长

在不断的学习(摸鱼)和实践中,第二周也快要结束了,这周总体来说还是蛮不错的比上周好很多(没有那么拘谨?)。前面两天一直在学习和摸鱼之后就修改了几个需求。这里记录一下学习到的新知识、小技巧、小细节,顺便再发表一下自己的小感想~

一、摸鱼与学习

摸鱼&感想

完善并提交上周需求修改:上周修没有修改移动端的(缺乏实际经验 之前也没写过移动端的),还是Q哥帮忙修改的(不得不表扬一下)。然后让我提交,好吧我竟然还不太熟悉。

看知识框架&面试题:这个就不多说了,改需求的就是给公司干的,学习是自己得到的(嗯有道理)。

学习新知识与回顾:其实看这些我记不住太多,反正知道怎么去改组件的一些样式还有怎么使用就好了。

  • Ant Design vue
  • Vue

收获

  • 规范修改提交流程:记得安装一下git插件。add--》commit 「提交的修改信息要规范:例如更新feat(编号):修改的内容」--》git push--》在jenkins上选择对应的项目--》点击build now等待构建完毕。
  • 移动端修改:通过v-if="ifMatched"和@media 关键字当当视口宽度小于或等于某一特定值时,媒体查询内的样式会被应用,以适应移动端。例如:
@screen-mobile-width: 768px; // 设定移动端的断点宽度

@media (max-width: @screen-mobile-width) {//要修改的样式}

二、实践中成长

实践

(1)修改官网弹框遮罩层背景颜色:就是之前的弹框遮罩层颜色太黑了改了个颜色。

  • 这里要注意哪里用到了弹框AModal哪里就要修改,不要漏了。
  • 知识点小记 :deep是一个深度选择器,接下来的样式会穿透scoped的限制,去影响到子组件的元素。
:deep(.ant-modal-mask) {
  background-color: rgba(102, 102, 102, 0.4);
}//这里其实不用deep也可以

  // deep的使用
  // 这里子组件的:deep会穿透scoped边界,并向下查找所有匹配.my-custom-class的选择器,包括子组件内部的元素,所以就影响到了子组件内部的inner element。
  //ParentComponent.vue
  <template>
    <ChildComponent class="my-custom-class" />
  </template>

  <style scoped>
    .my-custom-class {
      color: red;
    }

    :deep(.my-custom-class) {
      color: blue;
    }
  </style>

      
  //ChildComponent.vue
  <template>
    <div class="inner-element">I'm in the child component</div>
  </template>

  <style scoped>
    .inner-element {
    /* blue */
  }
</style>

(2)表单项样式修改:修改了一个模特上传表单的样式。

  • 由于这里只需要给文字换一下样式,就使用了一个插槽把文字拿出来单独设置一个class,然后去修改样式。
<template>
  <AFormItem name="name">
    <template #label>
      <span class="model-name">{{ xxx }}</span>
    </template>
    <AInput/>
  </AFormItem>
</template>
<style scoped>
  .model-name {
    color: #ffffff99;
    font-weight: 400;
    font-size: 14px;
  }
</style>

(3)首页banner修改:修改背景视频、文字和按钮的层级样式,以及添加蒙层。

  • 知识点小记1:使用v-html="t('global_home_text')", v-html则将数据作为HTML代码解析并渲染,所以不使用v-html识别不出来br换行。
  • 知识点小记2:绝对定位会脱离文档流,要给父容器添加position:relative,让子容器相对于父容器进行定位(子绝父相),不脱离文档流。需要更多了解的是BFC。这里先不写了后续写了再更新。
  • 知识点小记3:设置不同的层级可以使用 z-index,但只对具有定位(position)的元素生效。
<body>
  <div id="div1">Div 1</div>
  <div id="div2">Div 2</div>
  <div id="div3">Div 3</div>
</body>
<style>
  #div1 {
    position: absolute;
    z-index: 1; /* 层级最低 */
  }
  
  #div2 {
    position: absolute;
    z-index: 2; /* 中间层级 */
  }
  
  #div3 {
    position: absolute;
    z-index: 3; /* 层级最高 */
  }
</style>
  • 知识点小计4:需要判断移动端和中英文,显示相应的四个不同图片。有两个方法,一种是使用双重三元运算符,另一种是使用映射表。
<template>
    <div>
        <img :src="imageSrc" />
    </div>
</template>

<script lang="ts" setup>
    import CnPc from '@assets/CnPc.png';
    import EnPc from '@assets/EnPc.png';
    import CnMobile from '@assets/CnMobile.png';
    import EnMobile from '@assets/EnMobile.png';
  
    const isMobile = ref(false);
    const isCN = ifCNLocale();
    // 第一种双重三元运算符,外层先判断是否移动端,内层判断中英文。
    // 但是还是不要有这个了,双重的话确实难以理解。。。
    // const imageSrc = isMobile ? (isCN ? CnMobile : EnMobile) : (isCN ? CnPc : EnPc);
    // 第二种映射
    const imageSrcMap = {
        ['pc']: {
            'zh-CN': CnPc,
            en: EnPc,
        },
        ['mobile']: {
            'zh-CN': CnMobile,
            en: EnMobile,
        },
    };
    const imageSrc = ref('');
    onMounted(() => {
        isMobile.value = matchMobile();
        imageSrc.value = imageSrcMap[isMobile.value ? 'mobile' : 'pc'][isCN ? 'zh-CN' : 'en'];
    });
</script>

坑点

  • 坑点1:图片无法显示。(1)图片也是一个模块,需要import引入 (2)检查有无拼写错误。之后才发现是大小写错了(尴尬不敢说话)。一定要cv能复制就复制避免拼写错误、英文大小写问题。(3)最后还不行就重新启动项目。
  • 坑点2:图片模糊。切图导出的时候选择图片*n >= 实际尺寸的。比如图是375*812的,而实际尺寸是1000*2000(举个例子),那么就要选择3倍导出。
  • 坑点3:图片还未加载完毕异常提前显示。具体的:看代码吧。
<script setup lang="ts">
  const showVideoSwipper = ref(false);//1.刚开始设置为false
  
  onMounted(() => {
      setTimeout(() => {
          showSwipper.value = true;
      }, 1000);
  });//2.设置定时器,在组件挂载后等待1秒,将showVideoSwipper的值从false变为true
</script>

<template>
  <div class="home-container">
      <!-- 首页轮播组件carousel -->
      <a-carousel autoplay :autoplaySpeed="7000">
        <!-- 3.设置class:当showSwipper为false时,hide类将被添加到banner内,从而使banner透明度为0 -->
          <Banner :class="{ hide: !showSwipper }" />
      </a-carousel>
  </div>
<template>

  
<!-- Banner.vue内 -->
<style lang="less" scoped>
<!-- 4.组件内部设置opacity: 0; -->
.hide {
  opacity: 0;
}
</style>
<!-- 5.最后的结果就是,会黑屏(不可见)一秒之后再显示轮播图 -->

技巧

  • 修改调试技巧:先通过检查在界面修改样式,会更方便直观,调试好之后,再去项目里面修改代码,速度就快很多了(显然我还没有习惯)。
  • 项目无法显示,显示500内部错误:(1)看提示的错误原因,自己修改了哪里,初步定位错误原因(2)查看代码编写是否错误(3)使用log看哪一步没有显示出来(4)重启(比较浪费时间,最后在这样做)
  • 移动文件夹命令: pwd 查看当前目录,mv 原路径 目标路径。 例如:mv /Users/item/xxxx/ssss /Users/item/ 就是把ssss移动到item下面。
  • 快捷键:cm+c cm+v 快速复制下一行; cm+left/right定位到最左/右;cm+delete删除整行;option+left/right左右移动。

三、写在最后

  • 反正前两天没什么活,在学习摸鱼了~自我感觉上班比上课快乐(可能只是刚开始,希望以后也这么觉得)
  • 第一次写完了感觉没什么问题,一定要多细心排查几遍(真的很重要每次都被@太丢人了)
  • 工作过程中收获到的知识点可以记在todo list挺方便(Q哥教的好)
  • 另一个实习生好像就是来做杂活的(很辛苦什么都要会一点,她经常加班),招实习生进来不就是干活嘛呜呜怎么可能让我天天摸鱼做好心理准备
  • 愉快的一周吧~期待下周运动会虽然没报名,带薪去还是快乐的(但实习生没有衣服区别对待,我社恐一个人好尴尬。。)
  • 下周继续摸鱼&学习&工作吧。要制定一个自己的计划了,规划还是蛮重要的,好好想一下干什么。。。。
  • 碎碎念也就写在这里了,拜拜~下周继续碎碎念

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/779293.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

创维汽车开展年中总结会:创新创造·勇开拓 智慧经营·攀高峰

2024年7月3日&#xff0c;回顾上半年的工作成果&#xff0c;总结经验教训&#xff0c;明确下半年的发展方向和重点任务&#xff0c;创维汽车于山西省晋中市榆次区山西联合创维体验中心开展年中总结会。 创维集团、创维汽车创始人黄宏生&#xff1b;开沃集团联合创始人、首席执…

每日一更 EFK日志分析系统

需要docker和docker-compose环境 下面时docker-compose.yaml文件 [rootnode1 docker-EFK]# cat docker-compose.yaml version: 3.3services:elasticsearch:image: "docker.elastic.co/elasticsearch/elasticsearch:7.17.5"container_name: elasticsearchrestart: …

process.env 管理 Vue 项目的环境变量(Vue项目中环境变量的配置及调用)

简述&#xff1a;在构建 Vue 应用时&#xff0c;管理配置是开发中的一个重要部分。不同的环境&#xff08;如开发、测试和生产&#xff09;往往需要不同的配置&#xff0c;例如 API、 基础 URL、第三方服务的密钥等。使用环境变量可以帮助我们更好地管理这些配置。这里将介绍如…

2 极/2 零 (2P2Z) 补偿器

极/2 零 &#xff08;2P2Z&#xff09; 补偿器是模拟 II 型控制器的数字实现。它是一种滤波器&#xff0c;通过考虑两个极点和一个零点&#xff0c;将特定的增益和相位升压引入系统。您必须战略性地选择每个极点和零点的频率位置&#xff0c;这将有助于实现所需的系统性能。在该…

当需要对大量数据进行排序操作时,怎样优化内存使用和性能?

文章目录 一、选择合适的排序算法1. 快速排序2. 归并排序3. 堆排序 二、数据结构优化1. 使用索引2. 压缩数据3. 分块排序 三、外部排序1. 多路归并排序 四、利用多核和并行计算1. 多线程排序2. 使用并行流 五、性能调优技巧1. 避免不必要的内存复制2. 缓存友好性3. 基准测试和性…

手把手教你从零开始构建 AI 视频生成模型

在 GitHub 上发现一篇教程&#xff0c;作者详细介绍了如何使用 Python 语言&#xff0c;从零开始构建一个文本到视频生成模型。 涵盖了从理解理论概念到架构编码&#xff0c;最终实现输入文本提示即可生成视频的全过程。 相关链接 GitHub&#xff1a;github.com/FareedKhan-…

PD协议诱骗芯片,XSP08Q,XSP16应用笔记

XSP08Q是3C数码或小家电产品的Type-C接口控制芯片&#xff0c;它负责和PD充电器通讯&#xff0c;获取充电器的快充电压档位&#xff0c;如5V4A&#xff0c;9V3A&#xff0c;12V2A&#xff0c;15V3A&#xff0c;20V5A等等。 XSP08Q支持PD协议&#xff0c;BC1.2协议&#xff0c;Q…

Rakis: 免费基于 P2P 的去中心化的大模型

是一个开源的&#xff0c;完全在浏览器中运行的去中心化 AI 推理网络&#xff0c;用户无需服务器&#xff0c;打开即可通过点对点网络使用 Llama-3、Mistral、Gemma-2b 等最新开源模型。 你可以通过右上角的 Scale Worker &#xff0c;下载好模型后挂机就能作为节点加入到这个…

【全面讲解下Foxit Reader】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…

便携式气象站:探索自然的智慧伙伴

在探索自然奥秘、追求科学真理的道路上&#xff0c;气象数据始终是我们不可或缺的指引。然而&#xff0c;传统的气象站往往庞大而笨重&#xff0c;难以在偏远地区或移动环境中灵活部署。 便携式气象站&#xff0c;顾名思义&#xff0c;是一种小巧轻便、易于携带和安装的气象观测…

农资销售网站-计算机毕业设计源码54432

目录 摘要 Abstract 1绪论 1.1研究背景 1.2研究意义 1.3论文结构与章节安排 2农资销售网站系统分析 2.1可行性分析 2.1.1技术可行性分析 2.1.2经济可行性分析 2.1.3法律可行性分析 2.2系统功能分析 2.2.1功能性分析 2.2.2非功能性分析 2.3系统用例分析 2.4系统流…

比赛获奖的武林秘籍:03 好的创意选取-获得国奖的最必要前提

比赛获奖的武林秘籍&#xff1a;03 好的创意选取-获得国奖的最必要前提 摘要 本文主要介绍了大学生电子计算机类比赛和创新创业类比赛创意选取的重要性&#xff0c;并列举了好的创意选取和坏的创意选取的例子&#xff0c;同时说明了好的创意选取具有哪些特点&#xff0c;同时…

Tkinter布局助手

免费的功能基本可以满足快速开发布局&#xff0c; https://pytk.net/ iamxcd/tkinter-helper: 为tkinter打造的可视化拖拽布局界面设计小工具 (github.com) 作者也把项目开源了&#xff0c;有兴趣可以玩玩

Java中线程的常用方法(并发编程基础)

Java中线程的常用方法 sleep 调用sleep会让当前线程从Running进入TIMED WAITING状态其它线程可以使用 interrupt 方法打断正在睡眠的线程,这时sleep方法会抛出InterruptedException睡眠结束后的线程未必会立刻得到执行建议用TimeUnit的sleep代替Thread的sleep来获得更好的可读…

如何在PD虚拟机中开启系统的嵌套虚拟化功能?pd虚拟机怎么用 Parallels Desktop 19 for Mac

PD虚拟机是一款可以在Mac电脑中运行Windows系统的应用软件。使用 Parallels Desktop for Mac 体验 macOS 和 Windows 的最优性能&#xff0c;解锁强大性能和无缝交互。 在ParallelsDesktop&#xff08;PD虚拟机&#xff09;中如何开启系统的嵌套虚拟化功能&#xff1f;下面我们…

vulhub-activemq(CVE-2015-5254)

Apache ActiveMQ 5.13.0版本之前到5.x版本的安全漏洞&#xff0c;该程序引起的漏洞不限制代理中可以序列化的类。远程攻击者可以制作一个特殊的序列化 Java 消息服务 (JMS) ObjectMessage 对象&#xff0c;利用该漏洞执行任意代码。 Apache ActiveMQ 5.x ~ Apache ActiveMQ 5.1…

【人工智能】-- 智能机器人

个人主页&#xff1a;欢迎来到 Papicatch的博客 课设专栏 &#xff1a;学生成绩管理系统 专业知识专栏&#xff1a; 专业知识 文章目录 &#x1f349;引言 &#x1f349;机器人介绍 &#x1f348;机器人硬件 &#x1f34d;机械结构 &#x1f34d;传感器 &#x1f34d;控…

基于Android Studio电影购票系统

目录 项目介绍 图片展示 运行环境 获取方式 项目介绍 主要实为了方便用户随时随地进行电影购票。在配色方面选择了一些富有电影元素的颜色。主要能够实现的功能与流程为&#xff1a; 1.用户首先需要注册用户名填写密码。 2.用户可以用之前注册的用户名和密码进行登录。 3.登…

键盘异常的检测与解决方案

今天对象用Word写文档&#xff0c;按下Ctrl的时候&#xff0c;页面不停地上下滑动&#xff0c;导致无法正常编辑文本。 重启之后&#xff0c;仍然无法解决&#xff0c;推断是键盘坏了。 但是当按下Fn或其他功能键&#xff0c;焦点移除&#xff0c;页面就不会再抖动了。 现在…

[CP_AUTOSAR]_分层软件架构_内容详解

目录 1、软件分层内容1.1、Microcontroller Abstraction Layer1.2、ECU Abstraction Layer1.2.1、I/O HW Abstraction1.2.2、Communication Hardware Abstraction1.2.3、Memory Hardware Abstraction1.2.4、Onboard Device Abstraction1.2.5、Crypto Hardware Abstraction 1.3、…