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

news2024/10/5 13:17:57

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

一、摸鱼与学习

摸鱼&感想

完善并提交上周需求修改:上周修没有修改移动端的(缺乏实际经验 之前也没写过移动端的),还是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.coloradmin.cn/o/1901002.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

嵌入式Linux系统编程 — 7.2 进程的环境变量

目录 1 什么是进程的环境变量 2 环境变量的作用 3 应用程序中获取环境变量 3.1 environ全局变量 3.2 获取指定环境变量 getenv 4 添加/删除/修改环境变量 4.1 putenv()函数添加环境变量 4.2 setenv()函数 4.3 unsetenv()函数 1 什么是进程的环境变量 每一个进程都有一…

Node.js 生成vue组件

在项目根目录下创建 create.js /*** 脚本生成vue组件* 主要是利用node自带的fs模块操作文件的写入* ===========================================* 准备步骤:* 1.输入作者名* 2.输入文件名* 3.输入菜单名* 4.输入文件地址* ============================================* 操…

【公益案例展】厦门大学附属成功医院——国产数据库在综合三甲医院核心系统的应用...

‍ 达梦数据公益案例 本项目案例由达梦数据投递并参与数据猿与上海大数据联盟联合推出的 #榜样的力量# 《2024中国数据智能产业最具社会责任感企业》榜单/奖项”评选。 大数据产业创新服务媒体 ——聚焦数据 改变商业 厦门大学附属成功医院是一所集医疗、教学、科研、保健、疗…

C++基础(八):类和对象 (下)

经过前面的学习&#xff0c;我们已经翻过了两座大山&#xff0c;类和对象入门知识就剩下这一讲了&#xff0c;加油吧&#xff0c;少年&#xff01; 目录 一、再谈构造函数 1.1 构造函数体赋值 1.2 初始化列表&#xff08;理解&#xff09; 1.3 explicit关键字&#xff08;C…

代码随想录算法训练营第13天|二叉树的递归遍历、二叉树的迭代遍历、二叉树的统一迭代法、102.二叉树的层序遍历

打卡Day13 1.理论基础2.二叉树的递归遍历3.二叉树的迭代遍历3.二叉树的统一迭代法4.102.二叉树的层序遍历扩展107. 二叉树的层序遍历 II199.二叉树的右视图637.二叉树的层平均值429.N叉树的层序遍历515.在每个树行中找最大值116.填充每个节点的下一个右侧节点指针117. 填充每个…

ctfshow web入门 web338--web344

web338 原型链污染 comman.js module.exports {copy:copy };function copy(object1, object2){for (let key in object2) {if (key in object2 && key in object1) {copy(object1[key], object2[key])} else {object1[key] object2[key]}}}login.js var express …

Python + 在线 + 文生音,音转文(中文文本转为英文语音,语音转为中文文本)

开源模型 平台&#xff1a;https://huggingface.co/ars-语言转文本: pipeline("automatic-speech-recognition", model"openai/whisper-large-v3", device0 ) hf: https://huggingface.co/openai/whisper-large-v3 github: https://github.com/openai/wh…

使用自动化测试确保接口正确性的详细指南!

引言&#xff1a; 随着软件开发的迅速发展&#xff0c;接口的正确性成为了确保应用程序质量的关键要素之一。自动化测试是一种强大的工具&#xff0c;可以帮助开发人员和测试人员减少错误&#xff0c;提高测试覆盖率&#xff0c;并加快测试过程。本文将详细介绍从零开始如何使…

探索LlamaIndex:如何用Django打造高效知识库检索

简介 LlamaIndex&#xff08;前身为 GPT Index&#xff09;是一个数据框架&#xff0c;为了帮助我们去建基于大型语言模型&#xff08;LLM&#xff09;的应用程序。 主要用于处理、构建和查询自定义知识库。 它支持多种数据源格式 excel&#xff0c;txt&#xff0c;pdf&…

ELK优化之Filebeat部署

目录 1.安装配置Nginx 2.安装 Filebeat 3.设置 filebeat 的主配置文件 4.修改Logstash配置 5.启动配置 6.kibana验证 主机名ip地址主要软件es01192.168.9.114ElasticSearches02192.168.9.115ElasticSearches03192.168.9.116ElasticSearch、Kibananginx01192.168.9.113ng…

测试人员如何管理项目与风险预警

在平时工作过程中&#xff0c;你有没有因项目延时&#xff0c;需求频繁变更&#xff0c;开发提测质量不高&#xff0c;以及漏测的情况下&#xff0c;背了不少锅的情况呢&#xff1f; 作为测试人员&#xff0c;我们应该如何发挥积极主动性&#xff0c;进行项目管理&#xff0c;有…

VuePress 的更多配置

现在&#xff0c;读者应该对 VuePress、主题和插件等有了基本的认识&#xff0c;除了插件&#xff0c;VuePress 自身也有很多有用的配置&#xff0c;这里简单说明下。 ‍ ‍ VuePress 的介绍 在介绍了 VuePress 的基本使用、主题和插件的概念之后&#xff0c;我们再来看看官…

CTS单测某个模块和测试项

1 &#xff0c;测试单个模块命令 run cts -m <模块名> 比如&#xff1a;run cts -m CtsUsbTests模块名可以从测试报告中看&#xff0c;如下&#xff1a; 2&#xff0c; 测试单个测试项 run cts -m <模块名> -t <test_name> 比如&#xff1a;run cts -m ru…

基于大象机器人UltraArm P340机械臂和传送带,实现教育场景中的自动化分拣系统!

引言 今天我们将展示一个高度自动化的模拟场景&#xff0c;展示多个机械臂与传送带协同工作的高效分拣系统。在这个场景中&#xff0c;机械臂通过视觉识别技术对物体进行分类&#xff0c;并通过精确的机械操作将它们放置在指定的位置。这一系统不仅提高了分拣的速度和准确性&am…

dotnet ef工具使用

设置工具安装目录 dotnet tool install dotnetsay --tool-path G:\dotnet-tools安装 dotnet tool install --global dotnet-ef更新 dotnet tool update --global dotnet-ef查看版本 dotnet ef --version创建迁移文件 # 只有一个dbcontext dotnet ef migrations add init #…

http读书笔记

持久化 HTTP/1.1 和一部分的 HTTP/1.0 想出了 持久连接&#xff08;HTTP Persistent Connections&#xff0c; 也称为 HTTP keep-alive 或 HTTP connection reuse&#xff09; 的方法。 持久连接的特点是&#xff0c; 只要任意一端 没有明确提出断开连接&#xff0c; 则保持 T…

mysql 9 新特新

mysql9新特性 新特性Audit Log NotesC API NotesCharacter Set SupportCompilation NotesComponent NotesConfiguration NotesData Dictionary NotesData Type NotesDeprecation and Removal NotesEvent Scheduler NotesJavaScript ProgramsOptimizer NotesPerformance Schema …

微机原理与单片机 知识体系梳理

单片机笔记分享 我个人感觉单片机要记的东西很多&#xff0c;也很琐碎&#xff0c;特别是一些位、寄存器以及相关作用等&#xff0c;非常难以记忆。因此复习时将知识点整理在了一起做成思维导图&#xff0c;希望对大家有所帮助。内容不是很多&#xff0c;可能有些没覆盖全&…

轻预压:滚珠丝杆精度与刚性的平衡点!

预压是指在所需的工作负荷下&#xff0c;使滚珠丝杆预先承受一定的负荷&#xff0c;从而使滚珠丝杆的轴向向心度和侧向偏差达到较小的偏差范围&#xff0c;保证了滚珠丝杆的准确性和稳定性&#xff0c;也确保机器的高精度和长期运作的可靠性。 预压是滚珠丝杆设计中的一个重要参…

基于Java技术的人事管理系统

你好&#xff0c;我是专注于计算机科学领域的小野。如果你对人事管理系统感兴趣或有相关需求&#xff0c;欢迎私信交流。 开发语言&#xff1a; Java 数据库&#xff1a; MySQL 技术&#xff1a; B/S模式、Java技术、SpringBoot 工具&#xff1a; Eclipse、MySQL、浏览…