当前位置: 首页 > news >正文

重庆微信企业网站html5手机网站开发框架

重庆微信企业网站,html5手机网站开发框架,动漫制作专业需要艺考吗,网站 验证码 错误前言上一篇文章我们分析了 Layout 布局组件的设计和实现#xff0c;它的应用场景通常是局部布局。对于整个页面的布局#xff0c;element-ui 提供了 Container 布局容器组件#xff0c;专门用于 PC 管理后台页面的整体布局。需求分析我们先通过几幅图看一下页面的常见布局。… 前言上一篇文章我们分析了 Layout 布局组件的设计和实现它的应用场景通常是局部布局。对于整个页面的布局element-ui 提供了 Container 布局容器组件专门用于 PC 管理后台页面的整体布局。需求分析我们先通过几幅图看一下页面的常见布局。这两张图的布局在后台系统中很常见通过简单的 CSS 就可以实现。不过我们更喜欢用组件化的开发方式把这些 CSS 的细节封装到组件里如下el-container  el-headerHeaderel-header  el-mainMainel-main  el-footerFooterel-footerel-containerel-container  el-headerHeaderel-header  el-container    el-aside width200pxAsideel-aside    el-container      el-mainMainel-main      el-footerFooterel-footer    el-container  el-containerel-container我们使用了 、、、、 5 种组件来看一下它们各自的作用外层容器。当子元素中包含 或 时全部子元素会垂直上下排列否则会水平左右排列。顶栏容器。侧边栏容器。主要区域容器。底栏容器。这几个组件需要遵循如下约束 的子元素只能是后四者后四者的父元素也只能是 。了解了 element-ui Container 布局容器组件的需求后我们来分析它的设计和实现。设计和实现针对图示的布局我们可以通过 flex 的布局方式轻松实现element-ui 也是基于 flex 布局实现的接下来我们来分析各个组件的实现。ElContainer 组件先来看模板部分template  section classel-container    slotslot  sectiontemplate 组件会渲染成一个 标签并通过 slot 做内容分发。再来看一下 CSS 部分include b(container) {  display: flex;  flex-direction: row;  flex: 1;  flex-basis: auto;  box-sizing: border-box;  min-width: 0;}重点看一下 CSS 部分display:flex 创建了一个 flex 容器flex-direction:row 指定了内部元素是在水平方向排列。这里为什么还有 flex:1 呢因为 容器是支持嵌套的并且我们知道 flex:1 相当于 flex-grow:1;flex-shrink:1;flex-basis:0也就是当 被嵌套的时候它会占满剩余空间。flex-basis:auto 表示分配空间之前会先跟父容器预约自身内容大小的空间然后剩下的才会归入到剩余空间。 容器默认是水平排列当然也需要支持垂直排列我们可以给组件提供一个 direction 的 prop如果传入的 direction 是 vertical添加对应的 CSS。template  section classel-container :class{ is-vertical: isVertical }    slotslot  sectiontemplateexport default {  name: ElContainer,  componentName: ElContainer,  props: {    direction: String  },  computed: {    isVertical() {      if (this.direction  vertical) {        return true;      } else if (this.direction  horizontal) {        return false;      }    }  }};include when(vertical) {}如果传入的 direction 为 vertical则添加 is-vertical 的 CSS最终通过修改 flex-direction:column 实现内部元素是在垂直方向排列。回顾前面的一个需求当 容器的子元素中包含 或 时全部子元素会垂直上下排列否则会水平左右排列。实现它也很容易扩展计算属性 isVertical 的判断条件即可computed: {  isVertical() {    if (this.direction  vertical) {      return true;    } else if (this.direction  horizontal) {      return false;    }    return this.$slots  this.$slots.default     ? this.$slots.default.some(vnode  {       const tag  vnode.componentOptions  vnode.componentOptions.tag;       return tag  el-header || tag  el-footer;     })     : false;   }}这里用了一个小技巧this.$slots.default 获取的是默认插槽中的所有 vnodes 节点然后对他们遍历通过 vnode.componentOptions.tag 来判断这个 vnode 是不是 或者是 。vnode.componentOptions 并不在官网 API 里但是对于熟读 Vue 源码的人来说并不陌生。ElHeader 组件先来看一下模板部分template  header classel-header    slotslot  headertemplate 组件会渲染成一个 标签并通过 slot 做内容分发。再来看一下 CSS 部分include b(header) {  padding: $--header-padding;  box-sizing: border-box;  flex-shrink: 0;}其中 $--header-padding 是一个变量在 packages/theme-chalk/src/common/var.scss 文件中定义。flex-shrink: 0 表示即使空间不够也不会缩小 所占空间。通常来说头部都会有一个固定高度因此 允许你传入一个 height 的 props 来指定高度如果不指定的话提供一个默认高度。template  header classel-header :style{ height }    slotslot  headertemplateexport default {  name: ElHeader,  componentName: ElHeader,  props: {    height: {      type: String,      default: 60px    }  }};由于直接通过 :style 设置的样式所以这里传入高度的时候一定要携带单位。ElMain 组件先来看一下模板部分template  main classel-main    slotslot  maintemplate 组件会渲染成一个 标签并通过 slot 做内容分发。再来看一下 CSS 部分include b(main) {  // IE11 supports the  element partially https://caniuse.com/#searchmain  display: block;  flex: 1;  flex-basis: auto;  overflow: auto;  box-sizing: border-box;  padding: $--main-padding;}注意 标签在 IE11 中是部分支持的。通常 中包裹的内容完全由它的子元素来决定所以并不会设置高和宽只是通过 flex:1 来分配 容器的剩余空间。ElFooter 组件先来看一下模板部分template  footer classel-footer    slotslot  footertemplate 组件会渲染成一个 标签并通过 slot 做内容分发。再来看一下 CSS 部分include b(footer) {  padding: $--footer-padding;  box-sizing: border-box;  flex-shrink: 0;}和头部一样通常底部也会有一个固定高度因此 允许你传入一个 height 的 props 来指定高度如果不指定的话提供一个默认高度。template  footer classel-footer :style{ height }    slotslot  footertemplateexport default {  name: ElFooter,  componentName: ElFooter,  props: {    height: {      type: String,      default: 60px    }  }};ElAside 组件先来看一下模板部分template  aside classel-aside    slotslot  asidetemplate 组件会渲染成一个 标签并通过 slot 做内容分发。再来看一下 CSS 部分include b(aside) {  overflow: auto;  box-sizing: border-box;  flex-shrink: 0;} 组件用来渲染侧边栏而侧边栏通常会有宽度因此 允许你传入一个 width 的 props 来指定宽度如果不指定的话提供一个默认宽度。template  aside classel-aside :style{ width }    slotslot  asidetemplateexport default {  name: ElAside,  componentName: ElAside,  props: {    width: {      type: String,      default: 300px    }  }};总结element-ui 的 Container 布局容器组件的实现还是很简单的创建了一些语义化的标签利用插槽做内容分发通过 flex 实现布局效果。学习完这篇文章你可以顺便对 flex 布局、HTML5 的语义化标签做一下复习加深理解并了解到 Vue 源码中的一些小技巧。把不会的东西学会了那么你就进步了如果你觉得这类文章有帮助也欢迎把它推荐给你身边的小伙伴。下一篇预告 Element-UI  技术揭秘(5)色彩、字体、边框与图标。在这里留下你的爪印喔~
http://wiki.neutronadmin.com/news/353812/

相关文章:

  • 小说网站要怎么做西安网站设计建设公司 交通
  • 动漫网站怎么做的行唐县做网站电话
  • 网站不备案可以上线吗网页开发的流程或者步骤是什么
  • 烟台互网站建设公司名单花生壳盒子做网站服务器
  • 深圳网站设计公司如何大数据精准营销服务
  • 网站建设信息收集网站不用了怎么办
  • 遂昌赶街网站wordpress采集公众号图片
  • 国防教育网站建设说明书百度一下百度网页版
  • 大朗东莞网站建设vi设计作品
  • 我有一个域名怎么做网站国内大型游戏外包公司
  • 温州企业网站建设服务漯河做网站推广
  • 网站名注册视频模板在线制作网站
  • 网站框架搭建设计平台推广计划书模板范文
  • 企业网站怎么备案用js来做网站
  • seo网站建设做个电商平台需要哪些步骤
  • 建站系统下载泰安北京网站建设公司哪家好
  • 国外简约企业网站磁力链接 网站怎么做的
  • 龙岗网站建设价位微信公众号搭建微网站
  • 签订网站建设协议 注意事项海尔公司网站建设现状
  • 音乐网站开发的意义怎么制作网站链接手机
  • 网站建设归工商局管还是工信局管wordpress清除主题信息
  • 怎么用linux做网站跨境电商是什么意思
  • 网站设计流程及制作流程wordpress 远程 mysql
  • 网站首页做30个关键词wordpress主题怎么上传
  • 建设众筹网站盘锦做网站哪家好
  • 可以做水印的网站seo的实现方式
  • 陕西省交通建设集团公司门户网站手机网站 侧边栏导航
  • 合肥最好的网站建设公司排名qq钓鱼网站生成器手机版
  • 好玩的网站源码经营管理系统
  • 做网站公司做网站公司有哪些制作论坛类网站模板免费下载