uniapp 初始学习1

uni-app代码基本包括js,vue,css.在app端支持原生渲染nvue,可编译的kotlin和swift

掌握js就可以进行不同应用的开发

页面文件遵循 Vue 单文件组件 (SFC) 规范,即每个页面是一个.vue文件

.vue文件是一个自定义的文件类型,用类HTML语法描述一个VUE组件

.vue文件包含三种类型的顶级语言块<template> <script> <style>

vue-loader可以解析文件,提取每个语言块,用loader处理,奖他们组成一个ESMoudle 默认导出一个vue.js组件选项对象

vue-loaderloader 在计算机科学和软件开发领域有各自的含义和用途。

vue-loader

定义

vue-loader是一个webpack的加载器(loader),主要用于将Vue组件的单文件(.vue文件)转换为JavaScript模块。这个过程中,它会解析.vue文件,分离出其中的模板(template)、脚本(script)和样式(style),并将它们分别交给webpack和相关loader进行处理。

特性和用途

  • 编译模板:vue-loader能够处理.vue文件中的HTML模板,将其转换为可执行的JavaScript代码。
  • 处理样式:它支持使用CSS预处理器(如Less、Sass)来处理样式,并允许使用scoped CSS来避免样式冲突。
  • 热重载:在开发过程中,vue-loader支持组件的热重载,即在不刷新页面的情况下更新组件的修改。
  • 模块化:支持使用ES2015(ES6)及更高版本的模块语法来导入和导出Vue组件。

总结:vue-loader是Vue.js开发中不可或缺的工具,它极大地简化了Vue组件的开发和构建过程,使得开发者能够更加专注于业务逻辑的实现。


loader

定义

在计算机科学和软件开发中,loader通常指的是一个程序或模块,它负责在运行时或编译时加载和准备其他程序或数据以供使用。在不同的上下文中,loader可能有不同的具体实现和用途。

  • 在操作系统中,loader可能指的是负责加载操作系统或应用程序到内存中的程序。
  • 在Web开发中,特别是在使用webpack这样的模块打包工具时,loader指的是一种用于处理特定类型文件的脚本。这些脚本会在webpack的打包过程中被调用,用于将文件转换为模块,以便webpack可以进一步处理它们。

webpack中的loader

  • webpack是一个现代JavaScript应用程序的静态模块打包器(module bundler)。在webpack中,loader是处理模块内某个文件的预处理器。loader可以将文件从不同的语言(如TypeScript、CoffeeScript)转换为JavaScript,或将内联图像转换为DataURL。loader甚至允许你直接在JavaScript模块中import CSS文件!

样式

  • 默认匹配:/\.css$/

  • 一个 .vue 文件可以包含多个 <style> 标签。

  • <style> 标签可以有 scoped 或者 module 属性 (查看 scoped CSSCSS Modules) 以帮助你将样式封装到当前组件。具有不同封装模式的多个 <style> 标签可以在同一个组件中混合使用。

  • 任何匹配 .css 文件 (或通过它的 lang 特性指定的扩展名) 的 webpack 规则都将会运用到这个 <style> 块的内容中。


在Vue.js中,<style> 标签可以拥有 scoped 属性,但标准的HTML和CSS并不支持 module 属性直接用于 <style> 标签。不过,Vue.js 提供了一个类似于模块作用域样式的功能,通过单文件组件(.vue 文件)和特定的loader(如vue-loader)来实现,这通常被称为 CSS Modules。

scoped 属性

  • 作用scoped 属性是Vue.js特有的,用于确保样式只应用于当前组件的元素。Vue.js通过给组件的元素添加唯一的数据属性(如 data-v-xxxx),并在CSS选择器中添加对应的属性选择器,来实现样式的局部作用域。
  • 使用场景 :当你想要确保组件的样式不会影响到全局或其他组件时,scoped 属性非常有用。

CSS Modules

  • 实现方式 :虽然Vue.js本身不直接在 <style> 标签上提供 module 属性,但你可以通过配置vue-loader来启用CSS Modules。这通常涉及到在 <style> 标签中添加一个特殊的 module 属性(虽然这不是HTML的一部分,但vue-loader会识别并处理它),或者简单地通过在 .vue 文件中配置vue-loader来自动启用CSS Modules,而不需要在 <style> 标签中添加任何特殊属性。
  • 作用:CSS Modules 提供了一种将CSS类名映射到唯一标识符的方法,从而避免了全局命名冲突。每个类名都会映射到一个唯一的哈希值,这个哈希值被用作实际的类名。在JavaScript中,你可以通过导入的样式对象来访问这些映射后的类名。
  • 使用场景:当你想要更细粒度地控制CSS的作用域,或者当你想要在JavaScript中动态引用样式类名时,CSS Modules非常有用。

总结

  • Vue.js的 <style> 标签支持 scoped 属性以实现样式的局部作用域。
  • CSS Modules功能不是通过直接在 <style> 标签上添加 module 属性来实现的,而是通过vue-loader的配置来启用的。
  • 你可以根据项目的具体需求选择使用 scoped 样式或CSS Modules,或者两者结合使用。
相关推荐
Json____2 小时前
学法减分交管12123模拟练习小程序源码前端和后端和搭建教程
前端·后端·学习·小程序·uni-app·学法减分·驾考题库
云深时现月3 小时前
jenkins使用cli发行uni-app到h5
前端·uni-app·jenkins
diygwcom4 小时前
低代码可视化-uniapp开关选择组件-低码生成器
uni-app
fakaifa16 小时前
CRMEB Pro版v3.1源码全开源+PC端+Uniapp前端+搭建教程
前端·小程序·uni-app·php·源码下载
转角羊儿16 小时前
uni-app请求方法封装⑦
uni-app
java知路16 小时前
uniapp h5实现录音
uni-app
haodanzj18 小时前
在uniapp中封装请求接口 (带刷新token)
前端·javascript·uni-app
空&白18 小时前
uniapp h5地址前端重定向跳转
前端·uni-app
工业互联网专业19 小时前
Python毕业设计选题:基于Django+uniapp的公司订餐系统小程序
vue.js·python·小程序·django·uni-app·源码·课程设计
家里有只小肥猫19 小时前
关于vue生命周期
uni-app·uniapp