小程序之自定义组件 结合案例(会议OA的会议/投票管理及个人中心的搭建)详解 (4)

news2024/9/23 21:17:50

                                       ⭐⭐ 小程序专栏:小程序开发专栏

                                        ⭐⭐ 个人主页:个人主页


目录

一.前言

二.小程序自定义组件及其使用

2.1 自定义组件的使用

三.使用自定义组件完成会议功能界面的实现

   3.1 导航栏的实现

 3.2 会议界面内容的实现 

 四.投票管理界面

五.个人中心

今天的分享就到这啦!!!


一.前言

        继上一篇文章的首页搭建,今天来完成剩下的部分会议管理,投票管理及个人中心!!!

二.小程序自定义组件及其使用

        官网:自定义组件 / 介绍 (qq.com)icon-default.png?t=N7T8https://developers.weixin.qq.com/miniprogram/dev/framework/custom-component/

        开发者可以将页面内的功能模块抽象成自定义组件,以便在不同的页面中重复使用;也可以将复杂的页面拆分成多个低耦合的模块,有助于代码维护。自定义组件在使用时与基础组件非常相似。

2.1 自定义组件的使用

 右击新建一个文件夹,创建一个component文件,只有Windows10会报,windows7不会,我们只要添加一个设置即可:

"ignoreDevUnusedFiles": false,
"ignoreUploadUnusedFiles": false,

        一个自定义组件由 json wxml wxss js 4个文件组成。要编写一个自定义组件,首先需要在 json 文件中进行自定义组件声明(将 component 字段设为 true 可将这一组文件设为自定义组件):

{
  "component": true
}

在 wxss 文件中加入组件样式

<!-- 这是自定义组件的内部WXML结构 -->
<view class="inner">
  {{innerText}}
</view>
<slot></slot>

定义所需要的属性:

接着要在页面的 json 文件中进行引用组件。此时需要提供自定义组件文件路径

{
  "usingComponents": {
    "tabs": "/components/tabs/tabs"
  }
}

效果:

三.使用自定义组件完成会议功能界面的实现

        3.1 导航栏的实现

        前端代码,写在了自定义组件中 tabs.wxml:

        导航栏标题的判断选中的效果

<!-- 导航栏 -->
<view class="tabs">
    <view class="tabs_title">
        <view wx:for="{{tabList}}" wx:key="id" class="title_item  {{index==tabIndex?'item_active':''}}" bindtap="handleItemTap" data-index="{{index}}">
            <view style="margin-bottom:5rpx">{{item}}</view>
            <view style="width:30px" class="{{index==tabIndex?'item_active1':''}}"></view>
        </view>
    </view>
    <view class="tabs_content">
        <slot></slot>
    </view>
</view>

导航栏的样式 tabs.wxss:

/* 导航栏样式 */
.tabs {
    position: fixed;
    top: 0;
    width: 100%;
    background-color: #fff;
    z-index: 99;
    border-bottom: 1px solid #efefef;
    padding-bottom: 20rpx;
}

.tabs_title {
    /* width: 400rpx; */
    width: 90%;
    display: flex;
    font-size: 9pt;
    padding: 0 20rpx;
}

.title_item {
    color: #999;
    padding: 15rpx 0;
    display: flex;
    flex: 1;
    flex-flow: column nowrap;
    justify-content: center;
    align-items: center;
}

.item_active {
    /* color:#ED8137; */
    color: #000000;
    font-size: 11pt;
    font-weight: 800;
}

.item_active1 {
    /* color:#ED8137; */
    color: #000000;
    font-size: 11pt;
    font-weight: 800;
    border-bottom: 6rpx solid #333;
    border-radius: 2px;
}

在js里面定义属性以及定义点击的事件    tabs.js:

   /**
     * 组件的属性列表
     */
    properties: {
        // 这里定义属性,属性值可以在组件使用时指定
        tabList:Object
  
    },

 /**
     * 组件的方法列表
     */
    methods: {
        // 导航栏的方法
        handleItemTap(e){
            // 获取索引下标
            const {index} = e.currentTarget.dataset;
            // 触发 父组件的事件
            this.triggerEvent("tabsItemChange",{index})
            this.setData({
                tabIndex:index
            })
          }
    }

接着在会议文件夹中的前端中写入 list.wxml:

<tabs tabList="{{tabs}}"  bindtabsItemChange="tabsItemChange">
</tabs>

接着导入,在上篇文章就已经将所有的页面已经建好啦,现在只会写入代码即可在会议界面meeting的list.json导入:

    "usingComponents": {
        "tabs": "/components/tabs/tabs" 
    }

最后加入一些假数据 list.js:

 /**
     * 页面的初始数据
     */
    data: {
        tabs:['已取消','进行中','已结束','全部会议'],
}

效果:

 3.2 会议界面内容的实现 metting

前端代码  list.wxml:

<!-- 设置与导航栏的间距 -->
<view style="height: 40px;"></view>
<block wx:for-items="{{lists}}" wx:for-item="item" wx:key="item.id">
    <view class="list" data-id="{{item.id}}">
        <view class="list-img">
            <image class="video-img" mode="scaleToFill" src="{{item.image}}"></image>
        </view>
        <view class="list-detail">
            <view class="list-title"><text>{{item.title}}</text></view>
            <view class="list-tag">
                <view class="state">{{item.state}}</view>
                <view class="join"><text class="list-num">{{item.num}}</text>人报名</view>
            </view>
            <view class="list-info"><text>{{item.address}}</text>|<text>{{item.time}}</text></view>
        </view>
    </view>
</block>

样式设置 list.wxss:

/* 会议样式 */
.mobi-title {
    font-size: 12pt;
    color: #777;
    line-height: 110%;
    font-weight: bold;
    width: 100%;
    padding: 15rpx;
    background-color: #f3f3f3;
}

.mobi-icon {
    padding: 0rpx 3rpx;
    border-radius: 3rpx;
    background-color: #ff7777;
    position: relative;
    margin-right: 10rpx;
}

/*list*/
.list {
    display: flex;
    flex-direction: row;
    width: 100%;
    padding: 0 20rpx 0 0;
    border-top: 1px solid #eeeeee;
    background-color: #fff;
    margin-bottom: 5rpx;
    /* border-radius: 20rpx;
    box-shadow: 0px 0px 10px 6px rgba(0,0,0,0.1); */
}

.list-img {
    display: flex;
    margin: 10rpx 10rpx;
    width: 150rpx;
    height: 220rpx;
    justify-content: center;
    align-items: center;
}

.list-img .video-img {
    width: 120rpx;
    height: 120rpx;
    
}

.list-detail {
    margin: 10rpx 10rpx;
    display: flex;
    flex-direction: column;
    width: 600rpx;
    height: 220rpx;
}

.list-title text {
    font-size: 11pt;
    color: #333;
    font-weight: bold;
}

.list-detail .list-tag {
    display: flex;
    height: 70rpx;
}

.list-tag .state {
    font-size: 9pt;
    color: #81aaf7;
    width: 120rpx;
    border: 1px solid #93b9ff;
    border-radius: 2px;
    margin: 10rpx 0rpx;
    display: flex;
    justify-content: center;
    align-items: center;
}

.list-tag .join {
    font-size: 11pt;
    color: #bbb;
    margin-left: 20rpx;
    display: flex;
    justify-content: center;
    align-items: center;
}

.list-tag .list-num {
    font-size: 11pt;
    color: #ff6666;
}

.list-info {
    font-size: 9pt;
    color: #bbb;
    margin-top: 20rpx;
}
.bottom-line{
    display: flex;
    height: 60rpx;
    justify-content: center;
    align-items: center;
    background-color: #f3f3f3;
}
.bottom-line text{
    font-size: 9pt;
    color: #666;
}

导入后台假数据:

根据导航栏的不同状态,各自写了一个数组数据  list.js:

 /**
     * 页面的初始数据
     */
    data: {
        tabs:['已取消','进行中','已结束','全部会议'],
        lists: [
            {
              'id': '1',
              'image': '/static/persons/1.jpg',
              'title': '对话产品总监 | 深圳·北京PM大会 【深度对话小米/京东/等产品总监】',
              'num':'304',
              'state':'进行中',
              'time': '10月09日 17:59',
              'address': '深圳市·南山区'
            },
            {
              'id': '1',
              'image': '/static/persons/2.jpg',
              'title': 'AI WORLD 2016世界人工智能大会',
              'num':'380',
              'state':'进行中',
              'time': '10月09日 17:39',
              'address': '北京市·朝阳区'
            },
            {
              'id': '1',
              'image': '/static/persons/3.jpg',
              'title': 'H100太空商业大会',
              'num':'500',
              'state':'已取消',
              'time': '10月09日 17:31',
              'address': '大连市'
            },
            {
              'id': '1',
              'image': '/static/persons/4.jpg',
              'title': '报名年度盛事,大咖云集!2016凤凰国际论坛邀您“与世界对话”',
              'num':'150',
              'state':'进行中',
              'time': '10月09日 17:21',
              'address': '北京市·朝阳区'
            },
            {
              'id': '1',
              'image': '/static/persons/5.jpg',
              'title': '新质生活 · 品质时代 2016消费升级创新大会',
              'num':'217',
              'state':'已结束',
              'time': '10月09日 16:59',
              'address': '北京市·朝阳区'
            }
          ],
          lists1: [
            {
              'id': '1',
              'image': '/static/persons/1.jpg',
              'title': '对话产品总监 | 深圳·北京PM大会 【深度对话小米/京东/等产品总监】',
              'num':'304',
              'state':'进行中',
              'time': '10月09日 17:59',
              'address': '深圳市·南山区'
            },
            {
              'id': '1',
              'image': '/static/persons/2.jpg',
              'title': 'AI WORLD 2016世界人工智能大会',
              'num':'380',
              'state':'进行中',
              'time': '10月09日 17:39',
              'address': '北京市·朝阳区'
            },
            {
              'id': '1',
              'image': '/static/persons/3.jpg',
              'title': 'H100太空商业大会',
              'num':'500',
              'state':'进行中',
              'time': '10月09日 17:31',
              'address': '大连市'
            }
          ],
          lists2: [ 
            {
              'id': '1',
              'image': '/static/persons/1.jpg',
              'title': '对话产品总监 | 深圳·北京PM大会 【深度对话小米/京东/等产品总监】',
              'num':'304',
              'state':'已结束',
              'time': '10月09日 17:59',
              'address': '深圳市·南山区'
            },
            {
              'id': '1',
              'image': '/static/persons/2.jpg',
              'title': 'AI WORLD 2016世界人工智能大会',
              'num':'380',
              'state':'已结束',
              'time': '10月09日 17:39',
              'address': '北京市·朝阳区'
            }
          ],
          lists3: [
            {
              'id': '1',
              'image': '/static/persons/1.jpg',
              'title': '对话产品总监 | 深圳·北京PM大会 【深度对话小米/京东/等产品总监】',
              'num':'304',
              'state':'已取消',
              'time': '10月09日 17:59',
              'address': '深圳市·南山区'
            },
            {
              'id': '1',
              'image': '/static/persons/2.jpg',
              'title': 'AI WORLD 2016世界人工智能大会',
              'num':'380',
              'state':'已取消',
              'time': '10月09日 17:39',
              'address': '北京市·朝阳区'
            },
            {
              'id': '1',
              'image': '/static/persons/3.jpg',
              'title': 'H100太空商业大会',
              'num':'500',
              'state':'已取消',
              'time': '10月09日 17:31',
              'address': '大连市'
            },
            {
              'id': '1',
              'image': '/static/persons/4.jpg',
              'title': '报名年度盛事,大咖云集!2016凤凰国际论坛邀您“与世界对话”',
              'num':'150',
              'state':'已取消',
              'time': '10月09日 17:21',
              'address': '北京市·朝阳区'
            },
            {
              'id': '1',
              'image': '/static/persons/5.jpg',
              'title': '新质生活 · 品质时代 2016消费升级创新大会',
              'num':'217',
              'state':'已取消',
              'time': '10月09日 16:59',
              'address': '北京市·朝阳区'
            }
          ]
    },

改变导航栏页面的数据,根据会议状态做一个简单判断   list.js:

// 导航栏改变事件,改变值
    tabsItemChange(e){
        let tolists;
        if(e.detail.index==1){
            tolists = this.data.lists1;
        }else if(e.detail.index==2){
            tolists = this.data.lists2;
        }else if(e.detail.index==0){
            tolists = this.data.lists3;
        }else{
            tolists = this.data.lists;
        }
        this.setData({
            lists: tolists
        })
    },

效果:

 四.投票管理界面 vote

前端代码 :

<!-- 导航栏 -->
<tabs tabList="{{tabs}}"  bindtabsItemChange="tabsItemChange">
</tabs>
<!-- 设置与导航栏的间距 -->
<view style="height: 40px;"></view>
<block wx:for-items="{{vote1}}" wx:for-item="item" wx:key="item.id">
    <view class="list" data-id="{{item.id}}">
        <view class="list-detail">
            <view class="list-title"><text>{{item.title}}</text><text class="state">{{item.state}}</text>   </view>
           
            <view class="list-tag">
                <view class="join"> 参与投票人数: <text class="list-num">{{item.sum}}</text></view>
                <view class="join">已经投票人数: <text class="list-num">{{item.num}}</text></view>
            </view>
       
            <view class="list-info">投票截止时间: <text>{{item.time}}</text></view>
        </view>
    </view>
</block>

样式设计:

/* pages/vote/list/list.wxss */
/* 会议样式 */
/*list*/
.list {
    display: flex;
    flex-direction: row;
    width: 100%;
    padding: 0 20rpx 0 0;
    border-top: 1px solid #cac7c7;
    background-color: rgb(253, 244, 244);
    margin-bottom: 5rpx;
   
}
.list-title{
    color: rgb(219, 85, 23);
    font-weight: 1000;
    font-size: smaller;
    display: flex;
    margin: 20rpx 10rpx;
    /* width: 300rpx;
    height: 120rpx; */
    /* justify-content: center; */
    align-items: center;
}
.join{
    font-size: smaller;
    font-size: 11pt;
    color: rgb(85, 79, 79);
    margin-left: -300rpx;
    display: flex;
    justify-content: center;
    /* align-items: center; */
}
.list-num{
    font-weight: 680;
    color: red;
}
.state {
    font-size: 9pt;
    color: #81aaf7;
    width: 180rpx;
    border: 1px solid #93b9ff;
    border-radius: 2px;
    margin: 10rpx 0rpx;
    display: flex;
    justify-content: center;
    align-items: center;
}
.list-info {
    font-size: 9pt;
    color: rgb(17, 16, 16);
    margin-top: 20rpx;
    margin-left: 150px;
}

引入自定义标签:

{
    "usingComponents": {
        "tabs": "/components/tabs/tabs"
    }
}

定义一些假数据:

  /**
     * 页面的初始数据
     */
    data: {
        tabs:['待投票','历史投票','已投票'],
        vote1: [
            {
              'id': '1',
              'title': '【关于罢免张三的董事长职位】',
              'sum':'16人',
              'state':'还未进行投票',
              'time': '10月09日 17:59',
              'num': '10人'
            },
            {
              'id': '1',
              'title': '【世界人工智能大会是否上市】',
              'sum':'20人',
              'state':'还未进行投票',
              'time': '10月09日 17:39',
              'num': '7人'
            },
            {
              'id': '1',
              'title': '【H100太空商业大会是否召开】',
              'sum':'24人',
              'state':'还未进行投票',
              'time': '10月09日 17:31',
              'num': '21人'
            },
            {
              'id': '1',
              'title': '【关于李四的升职董事长的投票】',
              'sum':'10人',
              'state':'还未进行投票',
              'time': '10月09日 17:21',
              'num': '2人'
            }
          ],
          vote2: [
            {
              'id': '1',
            'title': '【关于公司是否支持空降总监的会议】',
              'sum':'23人',
              'state':'同意',
              'time': '10月09日 17:59',
              'num': '23人'
            },
            {
              'id': '1',
              'title': '【2016世界人工智能大会是否召开】',
              'sum':'23人',
              'state':'不同意',
              'time': '10月09日 17:39',
              'num': '23人'
            },
            {
              'id': '1',
              'title': '【H100太空商业大会是否召开】',
              'sum':'23人',
              'state':'弃权',
              'time': '10月09日 17:39',
              'num': '23人'
            }
          ],
          vote3: [ 
            {
              'id': '1',
              'title': '【关于王五的罢免的投票】',
              'sum':'34人',
              'state':'弃权',
              'time': '10月09日 17:59',
              'num': '31人'
            },
            {
              'id': '1',
              'title': '【2016世界人工智能大会的召开】',
              'sum':'34人',
              'state':'同意',
              'time': '10月09日 17:59',
              'num': '31人'
            },{
                'id': '1',
                'title': '【关于王五的罢免的投票】',
                'sum':'34人',
                'state':' 不同意',
                'time': '10月09日 17:59',
                'num': '31人'
              },
              {
                'id': '1',
                'title': '【2016世界人工智能大会的召开】',
                'sum':'34人',
                'state':'同意',
                'time': '10月09日 17:59',
                'num': '31人'
              },{
                'id': '1',
                'title': '【关于王五的罢免的投票】',
                'sum':'34人',
                'state':'同意',
                'time': '10月09日 17:59',
                'num': '31人'
              },
              {
                'id': '1',
                'title': '【世界人工智能大会的召开】',
                'sum':'34人',
                'state':'弃权',
                'time': '10月09日 17:59',
                'num': '31人'
              }
          ]
    },

导航栏改变事件:

// 导航栏改变事件,改变值
 tabsItemChange(e){
    let tolists;
    if(e.detail.index==0){
        tolists = this.data.vote1;
    }else if(e.detail.index==1){
        tolists = this.data.vote2;
    }else if(e.detail.index==2){
        tolists = this.data.vote3;
    }
    this.setData({
        vote1: tolists
    })
},

效果:

五.个人中心

前端代码 ucenter:

<view class="user">
    <image class="user-img" src="/static/persons/jennie1.jpg"></image>
    <view class="user-name">潇洒姿</view>
    <view class="user-oper">修改</view>
</view>
<view class="info">
    <view class="item1">
        <image class="item-icon" src="/static/tabBar/sdk.png"></image>
        <view class="item-title">我主持的会议</view>
        <view class="item-num">10</view>
        <view class="item-oper">></view>
    </view>
    <view class="item2">
        <image class="item-icon" src="/static/tabBar/sdk.png"></image>
        <view class="item-title">我参与的会议</view>
        <view class="item-num">7</view>
        <view class="item-oper">></view>
    </view>

</view>
<view class="info">
    <view class="item1">
        <image class="item-icon" src="/static/tabBar/sdk.png"></image>
        <view class="item-title">我发布的投票</view>
        <view class="item-num">6</view>
        <view class="item-oper">></view>
    </view>
    <view class="item2">
        <image class="item-icon" src="/static/tabBar/sdk.png"></image>
        <view class="item-title">我参与的投票</view>
        <view class="item-num">8</view>
        <view class="item-oper">></view>
    </view>

</view>
<view class="info">
    <view class="item1">
        <image class="item-icon" src="/static/tabBar/sdk.png"></image>
        <view class="item-title">消息</view>
        <view class="item-num">1</view>
        <view class="item-oper">></view>
    </view>
    <view class="item2">
        <image class="item-icon" src="/static/tabBar/sdk.png"></image>
        <view class="item-title">设置</view>
        <view class="item-num">10</view>
        <view class="item-oper">></view>
    </view>

</view>

样式设计:

/* pages/ucenter/index/index.wxss */
.user{
    display: flex;
    align-items: center;
    border-bottom: 8px solid rgb(236, 216, 219);
}
.user-img{
    width: 75px;
    height: 75px;
    margin: 10px;
}
.user-name{
    font-weight: 900;
    margin: 0 200rpx 0 50rpx;
    margin-left: 10px;
    color: palevioletred;
}
.user-oper{
    color: grey;
    width: 40px;
    margin-left: 10px;
}
.item-icon{
    width: 34px;
    height: 34px;
}
.item1,.item2{
padding: 5px;
display: flex;
align-items: center;
}
.item-title{
    width: 550rpx;

}
.item-num{
    
    color:rgb(231, 188, 217);
}
.item1{
    border-bottom: 1px solid rgb(236, 216, 219);
}
.item2{
    border-bottom: 5px solid rgb(236, 216, 219);
}
.item-oper{
    font-weight: 800;
   margin-left: 10px;
   width: 20px;
   color:rgb(100, 76, 84)

}

效果:

今天的分享就到这啦!!!

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

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

相关文章

SystemVerilog Assertions应用指南 Chapter1.30 使用“ intersect”控制序列的长度

在123节讨论的“ intersec”运算符可以有效地控制序列的长度,尤其是在时序窗口未定义上界的情况。每当使用可能性( eventuality)运算符时,检验器成功所需的时钟周期数没有限制。运算符 intersect提供了一个定义可能性运算符可以使用的最小和最大时钟周期数的机制。 属性…

计算机丢失MSVCP140.dll的解决方法分享

MSVCP140.dll是一个动态链接库文件&#xff0c;它是Microsoft Visual C 2015 Redistributable的一部分。这个文件包含了许多用于运行C程序的函数和类库。当计算机丢失这个文件时&#xff0c;可能会导致某些软件或游戏无法正常运行。 那么&#xff0c;为什么计算机会丢失MSVCP14…

Flex and Bison 阅读与学习笔记

本文的内容来源于本人阅读 flex & bison的笔记和项目工程学习中遇到的问题。如果你能从中获得一丝丝帮助&#xff0c;本人将不胜荣幸。 文章目录 Ⅰ、目录与批注前四章 引言和使用介绍flex 规范参考bison 参考规范其余内容 Ⅱ、相关练习代码学习历程代码实例 参考文献 Ⅰ、…

【文章摘要-20231019】Any-to-Any Generation via Composable Diffusion

论文链接 代码链接 作者提出了一个可组合的扩散模型&#xff0c;该模型体现为能够处理任何输入模态的组合&#xff0c;进而输出任何模态组合的新型生成模型&#xff0c;如语言、图像、视频或音频。不同于已经存在的生成式人工智能系统&#xff0c;该算法能够并行生成多个模态并…

Java基础 :内部类、枚举、泛型

内部类 概念 是类中的五大成分之一&#xff08;成员变量、方法、构造器、内部类、代码块&#xff09;&#xff0c;如果一个类定义在另一个类的内部&#xff0c;这个类就是内部类。 场景 当一个类的内部&#xff0c;包含了一个完整的事物&#xff0c;且这个事物没有必要单独…

工作之余Happy一下(实现时钟特效)

样式 测试代码&#xff1a; <!DOCTYPE html> <html> <head lang"en"><meta charset"UTF-8"><title>时钟特效</title><style> body{background: #000;}.content{width: 400px;margin: auto;color: #fff;}#title…

openGauss学习笔记-104 openGauss 数据库管理-管理数据库安全-客户端接入之SSL证书管理-证书替换

文章目录 openGauss学习笔记-104 openGauss 数据库管理-管理数据库安全-客户端接入之SSL证书管理-证书替换104.1 操作场景104.2 前提条件104.3 注意事项104.4 操作步骤 openGauss学习笔记-104 openGauss 数据库管理-管理数据库安全-客户端接入之SSL证书管理-证书替换 openGaus…

工业企业网络推广解决方案 | 网络营销专家分享 | 上海添力

在国内&#xff0c;工业企业如果想在线上做推广&#xff0c;其主要途径就是做搜索引擎推广&#xff0c;在几个常用的搜索引擎&#xff08;百度、360、搜狗、必应&#xff09;中&#xff0c;一般都是从百度开始做起。但不少工厂做百度广告&#xff0c;钱花了不少&#xff0c;就是…

做PPT或制作表情包时,不会把视频转成gif动图?5分钟学会

一、背景 当我们在做PPT时&#xff0c;不可避免的需要放一些视频&#xff0c;但视频占用空间太大&#xff0c;而且比较烦的是需要点一下才能播放。因此需要将视频转成gif动态&#xff0c;以自动播放。 GIF的全称是Graphics Interchange Format&#xff0c;可译为图形交换格式…

SQL题目记录

1.商品推荐题目 1.思路&#xff1a; 通过取差集 得出要推荐的商品差集的选取&#xff1a;except直接取差集 或者a left join b on where b null 2.知识点 1.except selectfriendship_info.user1_id as user_id,sku_id fromfriendship_infojoin favor_info on friendship_in…

ATE测试工程师的前景待遇如何?薪资天花板有多高?

在芯片行业&#xff0c;ATE测试工程师扮演着至关重要的角色。 他们不仅需要理解电路和芯片内部的工作原理&#xff0c;还需要利用各种测试工具和方法对芯片进行精确的测试和分析。那么ATE测试工程师前景如何&#xff1f;需要具备哪些技能要求呢&#xff1f; 首先来了解什么是…

【数据库范式】实际案例分析

前言 在日常业务研发过程中&#xff0c;我们常常需要与数据库表打交道。设计范式是数据表设计的基本原则&#xff0c;对于数据表的设计范式&#xff0c;我们特别容易忽略它的存在。很多时候&#xff0c;当数据库运行了一段时间之后&#xff0c;我们才发现数据表设计上有问题。然…

2023年中国润滑油分散剂市场需求量及行业竞争现状分析[图]

润滑油分散剂是一种两亲性化学品&#xff0c;可以增加油性部分以及水性部分在同一体系中的相容性&#xff0c;能降低分散体系中固体或液体粒子聚集的物质。换油时&#xff0c;可将有害的悬浮物从油中清除。 国内从60年代末开始试制丁二酰亚胺型分散剂&#xff0c;并于80年代初在…

93. 递归实现组合型枚举

题目&#xff1a; 93. 递归实现组合型枚举 - AcWing题库 思路&#xff1a; 1.从n个数中选择m个数&#xff0c;问有多少种选法。---->抽象为有m个坑位&#xff08;设置kenway[N]表示&#xff09;&#xff0c;其中填入编号为1~n的萝卜&#xff0c;问有几种填法。这里我们可…

二叉树题目:从中序与后序遍历序列构造二叉树

文章目录 题目标题和出处难度题目描述要求示例数据范围 解法一思路和算法代码复杂度分析 解法二思路和算法代码复杂度分析 题目 标题和出处 标题&#xff1a;从中序与后序遍历序列构造二叉树 出处&#xff1a;106. 从中序与后序遍历序列构造二叉树 难度 5 级 题目描述 要…

互联网行业汇总

互联网行业汇总&#xff0c;全网最全&#xff01;选行业不愁 从事互联网选什么行业&#xff1f;这似乎是很多朋友的困惑。 所以这里给大家把互联网行业做个细致的汇总&#xff0c;每个行业列举几个典型的APP&#xff0c;简单拆解下各自的盈利模式&#xff0c;希望能给大家提供参…

了解Netty,从IO开始

java程序员要想升级高级工程师或者成为架构师&#xff0c;绕不开Netty的学习&#xff0c;就算你不做IM即时通信&#xff0c;也不是网络编程的工作岗位&#xff0c;仅仅只是CRUD程序员&#xff0c;当你想要了解一下Dubbo、Redis、kafka、rabbitMQ、ES、zookeeper、nginx等等的底…

群硕与Microsoft Dynamics全球团队密切协作,加速ERP产品迭代

群硕具备强大的软件研发能力&#xff0c;搭建自动化测试平台&#xff0c;保证高质量交付。 ERP系统的引入被视为企业走向数字化转型的关键一步。 此系统有助于实现企业内部资源与外部资源的整合&#xff0c;通过软件把人、财、物、产、供、销及相应的物流、信息流、资金流、管…

大数据之LibrA数据库系统部署方案

组网方案 基本概念 FusionInsight LibrA集群的组网方案中包含如下节点&#xff0c;如表1所示。 网络平面类型 FusionInsight LibrA整个系统网络划分为2个平面&#xff0c;即业务平面和管理平面&#xff0c;两个平面之间采用物理隔离的方式进行部署&#xff0c;保证业务、管理…

Lua快速入门教程

文章目录 1、Linux安装Lua2、语法练习2.1、变量2.2、循环2.3、函数2.4、数组2.5、迭代器2.6、Table操作2.7、Lua 模块与包2.8、加载机制2.9、Lua 元表(Metatable) 3、Lua 协同程序(coroutine)4、文件IO操作4.1、简单模式4.2、完全模式 5、错误处理 内容来源菜鸟教程&#xff0c…