前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Web 前端开发代码规范

Web 前端开发代码规范

作者头像
青梅煮码
发布于 2023-03-02 12:46:53
发布于 2023-03-02 12:46:53
3.2K00
代码可运行
举报
文章被收录于专栏:青梅煮码青梅煮码
运行总次数:0
代码可运行
一、 引言

对于一个多人团队来说,制定一个统一的规范是必要的,因为个性化的东西无法产生良好的聚合效果,规范化可以提高编码工作效率,使代码保持统一的风格,以便于代码整合和后期维护。

二、 HTML/CSS规范

2.1 浏览器兼容

根据公司业务要求而定,一般:

  • 主流程测试:Chrome 30+、IE9+;
  • 完整测试: Chrome 21、IE8+、360浏览器、微信webview/QQ手机浏览器。

2.2 html代码规范

2.2.1声明与编码

1、html头部声明统一:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>

2、页面编码统一:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<meta charset="UTF-8"> <!-- ie6也支持,无须担心 --> 

2.2.2格式缩进

html编码统一格式化显示,使用一个Tab键进行分层缩进 (2个空格宽度),使整个页面结构层次清晰,方便阅读和修改。

2.2.3 模块注释

html较大独立模块之间注释格式统一使用:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!-- start: XXX模块 --><!-- end: XXX模块 -->

或者:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!-- XXX模块 --><!-- /XXX模块 -->

2.2.4标签与属性

1、由于html标签和属性不区别大小写,所有建议都采用小写,尤其是自定义标签和属性名,否定js中取不到,如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<div data-bgColor="red"></div>

$('div').data('bgColor');  // 取不到,已自动被浏览器转成了data-bgcolor

2、所有html属性必须添加双引号(非单引号)。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 禁止
<div id=mainframe><div id='mainframe'>

// 推荐
<div id="mainframe">

3、所有标签必须采用合理嵌套。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 禁止
<p><b></p></b>

// 推荐
<p><b></b></p>

// 禁止inline级标签嵌套block级标签
<span><div></div></span>

4、所有<、&、>等特殊符号(非标签一部分)用编码表示。< 编码成< ,>编码成>,&编码成&

5、img标签中必须添加alt属性。如: <imgsrc="…" alt="logo" />

6、标签在运用时,应尽量使用语义化标签,如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<h1>标题<h1>
<lable for="user">用户名:</lable>
<input name="username" id="user">

在语义不明显,既可用div也可用p时,应优先考虑p标签。

2.3 CSS代码规范

2.3.1 CSS引用规范

1、所有CSS均为外部调用,不得在页面书写任何内部样式或行内样式;

2、html页面引入样式文件:

统一使用link标签,少用@import(原生import有加载性能问题),sass、less、vue.js等文件使用import命令除外(因为最终前端构建工具会将引入文件编译成一个css文件)。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<link rel="stylesheet" href="xxx.css"> <!-- type="text/css"可以省略,清爽 -->

2.3.2 CSS注释规范

1、css头部文档注释( 统一加上@charset声明 ),如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@charset "utf-8";

/**
* @created :   2017/09/15
* @author  :   Mr.Wang
* @version :   v1.0
* @desc    :   XX模块
*/
(web前端学习交流群:328058344 禁止闲聊,非喜勿进!)

关于”version”,如果对代码有修改更新version版本号,并添加相关注释。

2、内部模块之间注释(建议 @模块英文名,好查找):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/* @info 商品信息区
----------------------------------------------------------------*/
.infoArea{}

/* 单行注释 */
.specArea{}

/* @price 商品价格区
----------------------------------------------------------------*/
.price{}

2.3.3 CSS书写规范

1、样式书写不做强约,可分行或单行

推荐单行,理由:直观、模块之间分隔鲜明,有全局感。

2、样式中属性排序规则:先外部 > 再自身 > 后内部,推荐工具( CSScomb )

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  A.)影响文档流的属性(display, position, float, clear, visibility, table-layout等)

  B.)自身盒模型的属性(width, height, margin, padding, border等)

  C.)排版相关属性(font, line-height, text-align, text-indent, vertical-align等)

  D.)装饰性属性(color, background, opacity, cursor等)

  E.)生成内容的属性(content, list-style, quotes等)

3、所有CSS属性和值必须采用小写的形式。如:FONT-SIZE:12PX必须改为font-size:12px;

4、关于css背景图片(关键字:合并,缩写,去引号), 引号不是必须的,而且在某些浏览器上加引号反而出错:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 不推荐
.canbox{
   background-color: #ff6600;
   background-image: url("/img/xxx.png");
}

// 推荐(合并、去除引号)
.canbox {
   background: #f60 url(/img/xxx.png); 
}

5、属性为0值,去除单位。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 不推荐
.wrap{
   margin: 0px 0px 5px 8px;
}

// 推荐
.wrap {
   margin: 0 0 5px 8px;
}

6、所有CSS的命名应语义化,如:回复框,.replyBox{…},禁止用拼音缩写命名,如.hfk{…}。

7、清除浮动时用.clearfix,禁止用无语义的 <pstyle="clear:both"></p>清除。

8、用来显示动态文本输入的地方,样式里必须加上强制英文换行:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
word-break: break-all; word-wrap: break-word; overflow-x: hidden; 

如果要显示省略号加上:text-overflow: ellipsis;

9、上下相邻的两模块尽量避免混用margin-bottom,margin-top,否则会产生重叠现象。

三、 JavaScript规范

3.1 JS文件引用

1、引入格式:

脚本语言发展至今,也只有js混的最好了,所以type=”text/javascript”类型指定可以省去。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<script src="model.js"></script>

2、引入位置: body标签内最后部(非body外面), 减少因载入脚本而造成其他页面内容阻塞的问题(js单线程)。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<html>
<body>
<div>页面内容….</div>
<script src="model.js"></script>
</body>
</html>

3、引入方式:html页面中禁止直接编写js代码,统一使用 <script> 外部引用方式,以便打包压缩和缓存。

3.2 JS代码缩进

3.2.1 整体层次

使用 Tab 键进行代码缩进 (4个空格宽度) 。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
(function() {
var i = 0;
function innerFun() {
var j = 0;
       ……
   }
}); 

运算符(=、==,&&、+/-等)两侧应各空一个格,块级{}左侧也应该空出一格

3.2.2 局部间隔

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 不推荐
var arr=[1,2],str='hello'+'Lucy';

var myfun=function(arg){
//todo…
}

// 推荐
var arr = [1,2], 
   str = 'hello' + 'Lucy';

var myfun = function(arg) {
//todo…
} 
(web前端学习交流群:328058344 禁止闲聊,非喜勿进!)

3.3 JS注释规则

3.3.1 文件头部注释

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
* @created :  2017/09/15
* @author  :  Mr.Wang
* @version :  v1.0
* @desc    :  当前js模块功能描述
* @e.g.    :  方法用例,如:$('.title').tip();
*/ 

3.3.2 方法注释及单行注释

1、对于一个较复杂的方法和函数,可用采用多行注释,以便作详情的描述。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
* 此方法是用于解析tpl模块
* 通过分析html中结构…
*/

2、单行注释

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var funName = function(arg1, arg2) {
this.arg1 = arg1;

// 单行注释说明(上面添加一空行, //与说明之间空一格)
this.arg2 = arg2;
}; 

3.4 命名规则

变量名应由 26 个大小写字母(A..Z,a..z),10 个数字(0..9),和“_”(下划线)组成。

1、通常, 使用”驼峰式”写法,对象、函数和实例时尤其如此。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 不推荐
var is_my_object = {};
var is-my-object = {};

// 推荐
var isMyObject = {};

2、构造函数或类时使用驼峰式大写

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 不推荐
var bad = new user({
    name: 'nope'
});
// 推荐
var good = new User({
    name: 'nope'
});

3、常量大写,并用下划线分隔,形式如:NAMESLIKETHIS

3.5 编码模式

为了规范代码严谨风格,推荐严格模式(Strict Mode),即总是在模块顶部声明 ‘use strict’;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
(function(){
'use strict';
function innerFun(){
var j = 0;
       ……
   }
});

严格模式的一大目标是显性的抛出错误,让你能更方便更快的调试一些隐性的错误。

1、防止意外的创建了全局变量。

非严格模式下,为一个未申明的局部变量赋值时会自动创建一个同名的全局变量,这是Js程序中最容易出现的错误之一,在严格模式下这么做会显性的抛出异常。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 严格模式下会抛出异常
(function() {
   some = 'foo';
}());

2、防止函数中的this指针意外指向全局。

非严格模式下,函数中未被定义或为空( null or undefined)的this会默认指向全局环境(global)。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
window.color = 'red';
function getColor() {
   console.log(this.color);
}

// 在严格模式中会报错, 非严格模式中则提示red
getColor();

3、防止重名。

当编写大量代码时,对象属性和函数参数很容易一不小心被设置成一个重复的名字。严格模式在这种情况下会显性的抛出错误

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 重复的变量名,在严格模式下会报错。
function doSomething(value1, value2, value1) {
//code
}

// 重复的对象属性名,在严格模式下会报错。
var object = {
   foo: 'bar',
   foo: 'baz'
};

4、对只读属性修改/删除时会抛出异常。

ES5中可为对象特定属性设为只读或让整个对象不可修改。 但在非严格模式中尝试修改一个只读属性只会默不做声的失败。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var person = {};
Object.defineProperty(person, 'name' {
   writable: false,
   value: 'Nicholas'
});

// 在非严格模式时,沉默的失败,在严格模式则抛出异常
person.name = 'John';

5、不要在全局环境下启用严格模式。

为了兼容第三方代码可能没有为严格模式做好准备而引发的问题,最好把开启严格模式的指令作用于自己独立的模块/函数里。

3.6 推崇建议

—— 变量

声明变量必须加上 var 关键字. 否则变量就会暴露在全局上下文中, 这样很可能会和现有变量冲突(es6中let修复了这个问题)。

—— 逗号

不要加多余的逗号,这可能会在IE下引起错误,同时如果多一个逗号某些ES3的实现会计算多数组的长度。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 不推荐
var hero = {
 firstName: 'Kevin',
 lastName: 'Flynn',
};

// 推荐
var hero = {
 firstName: 'Kevin',
 lastName: 'Flynn'
};

—— 分号

如果仅依靠语句间的隐式分隔, 有时会很麻烦.而且有些情况下, 漏掉分号会很危险.

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
;(function(){
var i = 0;
function innerFun(){
var j = 0;
    ……
  }
});

—— {},[]

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 不推荐
var item1 = new Object(),  item2 = new Array();

// 推荐
var item1 = {},  item2 = [];

(解释:new关键字的使用 除了在需要实例化一个对象,或罕见的需要延时加载数据的情况外,基本上不需要使用new关键字。在Javascript里分配大量的new变量地址是一项很慢的操作,为了效率起见,应该始终使用对象符号。)

—— 字符串,统一用单引号

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 不推荐
var name = "Bob Parr";

// 推荐
var name = 'Bob Parr';

—— === 和 !== 操作符

使用 === 和 !== 操作符会相对好点。== 和 != 操作符会进行类型强制转换。 特别是, 不要将 == 用于与错值比较(false,null,undefined,“”,0,NaN)。

—— 块

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 不推荐
if (test)
return false;
// 推荐
if (test) return false;
// 或
if (test) {
return false;
}
// 不推荐
function() { return false; }
// 推荐
function() {
return false;
}
(web前端学习交流群:328058344 禁止闲聊,非喜勿进!)

—— 不要使用eval()

只用于解析序列化串 (如: 解析 RPC 响应)

eval() 会让程序执行的比较混乱, 当 eval() 里面包含用户输入的话就更加危险.

可以用其他更佳的, 更清晰, 更安全的方式写你的代码, 所以一般情况下请不要使用 eval().

当碰到一些需要解析序列化串的情况下(如, 计算 RPC 响应), 使用 eval 很容易实现.

—— js常见参数命名建议

元素:elem, 参数:arg,对象:obj,数组:arr, 指令:ret,长度:len

四、 jQuery性能优化

——总是从ID选择器开始继承

jQuery中最快的筛选器是ID筛选器,这是因为它直接和JS原生方法getElementById()对应。

——在class前使用tag

第二快是tag选择器, 因为它和JS原生方法getElementsByTagName() 对应。jQuery中class选择器是最慢的,因为在IE浏览器下它会遍历所有的DOM节点。

综上几点:

  1. 如果查找(‘. class’),应使用(‘#id > tag. class’)来缩小DOM Tree的搜索范围。
  2. #id前面不要用tag来修饰。写成$(‘div#id’)会降低性能,因为JS会遍历所有 的div元素来查找id为’id’的哪一个节点:
  3. #id1也不需要由#id2来修饰。写成$(‘#id2 #id1’) 是画蛇添足,降低性能。

——缓存JQuery对象

要养成将jquery对象缓存进变量的习惯,避免进行多次查找,另外为了区分普通的JS对象和jQuery对象,建议在变量首字母前加上$符号。如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var $box = $('#wrap').find('.box');
$box.addClass('class');
$.ajax({
   $box.html('text');
});

——合理使用链式操作

可以减少对DOM Tree的访问以及代码量。如代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$('div').addClass('className').html('html code').click(function(){
  alert(1);
}); 

——使用子查询

使用children(), find(), filter()来进行子查询。如代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$('div p').click(function(){
  ……
}); 
// 上面替换成如下
$('div').find('p').click(function(){
  ……
}); 

——减少DOM操作

当要进行DOM插入时,将所有元素在内存中封装成一个元素,一次性插入。

——自定义数据属性

dom结构上添加自定义属性:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<div id="wrap" data-foo="123"></div> 
// 取数据:
$('#wrap').data('foo'); 
// 存数据:
$('#wrap').data('foo', {a:1,b:2} );

附录

命名规则:

  1. 所有文件夹命名,如需要两个单词表示的,使用”-“中划线连接(如:img-plug)。
  2. 所有文件(.html、.css、.js、图片)命名,如需要两个单词表示的,使用””下划线连接符(如:indexinfo.html)。
  3. 所有素材图片应将文件名第一个单词命名为图片分类,第二个单词为图片名称,第三个单词可以是数字或其它内容,以下为图片命名细则:
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
icon_xxx.gif   //图标文件名 
btn_xxx.gif    //按钮文件名 
corner_xxx.gif  //边角文件名 
banner_xxx.gif  //广告条文件名 
bg_xxx.gif      //背景图片文件名 
flash_xxx.gif     //flash文件名 
temp_xxx.gif  //临时测试用文件名 
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-06-07 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
《BERT基础教程:Transformer大模型实战》读书笔记
BERT,Bidirectional Encoder Representations from Transformers,多Transformer的双向编码器表示法。
johnny666
2024/09/26
3640
​浅析多模态大模型的前世今生
前段时间 ChatGPT 进行了一轮重大更新:多模态上线,能说话,会看图!微软发了一篇长达 166 页的 GPT-4V 测评论文,一时间又带起了一阵多模态的热议,随后像是 LLaVA-1.5、CogVLM、MiniGPT-5 等研究工作紧随其后,到处刷屏。大模型的多模态能力到底是怎么来的?今天来分享一下多模态相关的一些工作和个人的理解。
腾讯技术工程官方号
2023/11/01
3.6K0
​浅析多模态大模型的前世今生
大语言模型的预训练[1]:基本概念原理、神经网络的语言模型、Transformer模型原理详解、Bert模型原理介绍
预训练属于迁移学习的范畴。现有的神经网络在进行训练时,一般基于反向传播(Back Propagation,BP)算法,先对网络中的参数进行随机初始化,再利用随机梯度下降(Stochastic Gradient Descent,SGD)等优化算法不断优化模型参数。而预训练的思想是,模型参数不再是随机初始化的,而是通过一些任务进行预先训练,得到一套模型参数,然后用这套参数对模型进行初始化,再进行训练。
汀丶人工智能
2023/07/17
6.3K0
大语言模型的预训练[1]:基本概念原理、神经网络的语言模型、Transformer模型原理详解、Bert模型原理介绍
一文读懂 Transformer 神经网络模型
自从最新的大型语言模型(LLaM)的发布,例如 OpenAI 的 GPT 系列、开源模型 Bloom 以及谷歌发布的 LaMDA 等,Transformer 模型已经展现出了其巨大的潜力,并成为深度学习领域的前沿架构楷模。
Luga Lee
2023/09/22
41.1K1
一文读懂 Transformer 神经网络模型
AAAI 2024 | 利用通道模态冗余实现端到端 RGB-D 图像压缩
RGB-D 图像是一种重要的 3D 数据格式。它已被广泛用于 3D 场景重建、突出目标检测、机器人与自主导航、医学影像与健康监测、环境监测等领域。与 RGB 图像不同,深度图像包含有关从视点到场景对象表面的距离的信息,该视点提供了 3D 场景之间的深度信息。因此,RGB-D联合分析方法在计算机视觉任务中很受欢迎。然而,这些方法使用额外的模态,这将带来多余的存储和传输成本。因此,设计一个高效的RGB-D图像压缩方法是一项重要且具有挑战性的工作。
用户1324186
2024/03/26
6330
AAAI 2024 | 利用通道模态冗余实现端到端 RGB-D 图像压缩
学界 | 超越 BERT 和 GPT,微软亚洲研究院开源新模型 MASS!
AI 科技评论按:自 2018 年以来,预训练无疑是自然语言处理(NLP)领域中最热门的研究课题之一。通过利用 BERT、GPT 和 XLNet 等通用语言模型,该领域的研究者们在自然语言理解方面已经取得了许多重大的突破。然而,对于序列到序列的自然语言生成任务,这些主流的预训练方法并没有带来显著的改进,对此,微软亚洲研究院提出了一个全新的通用预训练方法——MASS,在该任务中可以得到比 BERT 和 GPT 更好的效果。
AI科技评论
2019/07/05
7250
学界 | 超越 BERT 和 GPT,微软亚洲研究院开源新模型 MASS!
TeaForN:让Teacher Forcing更有"远见"一些
本文介绍Google新提出的一种名为"TeaForN"的缓解Exposure Bias现象的方案,来自论文《TeaForN: Teacher-Forcing with N-grams》,它通过嵌套迭代的方式,让模型能提前预估到后N个token(而不仅仅是当前要预测的token),其处理思路上颇有可圈可点之处,值得我们学习
mathor
2021/07/08
9730
BiomedGPT:一个用于多种生物医学任务的通用视觉-语言基础模型
生信菜鸟团
2024/12/05
4610
BiomedGPT:一个用于多种生物医学任务的通用视觉-语言基础模型
Transformers回顾 :从BERT到GPT4
人工智能已成为近年来最受关注的话题之一,由于神经网络的发展,曾经被认为纯粹是科幻小说中的服务现在正在成为现实。从对话代理到媒体内容生成,人工智能正在改变我们与技术互动的方式。特别是机器学习 (ML) 模型在自然语言处理 (NLP) 领域取得了重大进展。一个关键的突破是引入了“自注意力”和用于序列处理的Transformers架构,这使得之前主导该领域的几个关键问题得以解决。
deephub
2023/08/28
4070
Transformers回顾 :从BERT到GPT4
Long-Context下LLM模型架构全面介绍
随着ChatGPT的快速发展,基于Transformer的大型语言模型(LLM)为人工通用智能(AGI)铺平了一条革命性的道路,并已应用于知识库、人机界面和动态代理等不同领域。然而,存在一个普遍的限制:当前许多LLM受资源限制,主要是在较短的文本上进行预训练,使它们对现实世界中常见的较长的上下文提示不太有效。本文对基于Transformer的LLM模型架构的进展进行了全面的介绍。
zenRRan
2023/11/29
2.1K0
Long-Context下LLM模型架构全面介绍
【论文笔记】Multi-Domain Dialogue State Tracking based on State Graph
​ 现有的方法通常将以前的对话状态与对话历史连接作为编码器的输入。它们依赖于编码器的自我注意机制来连接其中的 token。然而,编码器可能会注意到虚假的联系,从而导致错误的推断。
yhlin
2023/02/27
1.3K0
【论文笔记】Multi-Domain Dialogue State Tracking based on State Graph
多模态大模型篇
在CV方向上,一般我们输入的都是图片,无论这个图片多大,都会resize到一个统一的尺寸。最终经过CNN的提取,变成一个特征向量,那么这个特征向量的维度是一样的。再经过softmax变成一个分类(Class)的概率
算法之名
2023/10/16
9680
多模态大模型篇
FlowSeq、mBART、BERT-fused、mRASP、mRASP2...你都掌握了吗?一文总结机器翻译必备经典模型(三)
机器之心专栏 本专栏由机器之心SOTA!模型资源站出品,每周日于机器之心公众号持续更新。 本专栏将逐一盘点自然语言处理、计算机视觉等领域下的常见任务,并对在这些任务上取得过 SOTA 的经典模型逐一详解。前往 SOTA!模型资源站(sota.jiqizhixin.com)即可获取本文中包含的模型实现代码、预训练模型及 API 等资源。 本文将分 3 期进行连载,共介绍 18 个在机器翻译任务上曾取得 SOTA 的经典模型。 第 1 期:RNNsearch、Multi-task、attention-model
机器之心
2023/03/29
1K0
FlowSeq、mBART、BERT-fused、mRASP、mRASP2...你都掌握了吗?一文总结机器翻译必备经典模型(三)
【论文笔记】Jointly Optimizing State Operation Prediction and Value Generation for Dialogue State Tracking
​ 现有的方法利用 BERT 编码器和基于拷贝的 RNN 解码器,其中编码器预测状态操作,并由解码器生成新的插槽值。然而,在这种堆叠的编码器 - 解码器结构中,操作预测目标 只影响 BERT 编码器,而值生成目标 主要 影响 RNN 解码器。此外,在框架中,编码器是预先训练的,而解码器则没有预先训练。
yhlin
2023/02/27
8590
【论文笔记】Jointly Optimizing State Operation Prediction and Value Generation for Dialogue State Tracking
大模型的模型压缩与有效推理综述
本文对大型语言模型的压缩和效率推理进行了综述。大型语言模型基于Transformer架构,具有强大的性能,但也带来了巨大的内存和计算成本。本文从算法角度对大型语言模型的压缩和效率推理方法进行了分类,包括量化、剪枝、知识蒸馏、紧凑架构设计和动态网络。大型语言模型有两个显著特点:
算法进阶
2024/07/10
6260
大模型的模型压缩与有效推理综述
Transformers 4.37 中文文档(十二)
🤗 Transformers 是一个预训练的最先进模型库,用于自然语言处理(NLP)、计算机视觉以及音频和语音处理任务。这个库不仅包含了 Transformer 模型,还有像现代卷积网络这样的非 Transformer 模型,用于计算机视觉任务。如果你看一下今天最流行的消费产品,比如智能手机、应用和电视,很可能背后都有某种深度学习技术。想要从智能手机拍摄的照片中移除背景物体?这就是一个全景分割任务的例子(如果你还不知道这是什么,不用担心,我们将在接下来的部分中描述!)。
ApacheCN_飞龙
2024/06/26
5900
Transformers 4.37 中文文档(十二)
最强NLP预训练模型!谷歌BERT横扫11项NLP任务记录
作者:Jacob Devlin、Ming-Wei Chang、Kenton Lee、Kristina Toutanova
机器之心
2018/10/22
1.3K0
最强NLP预训练模型!谷歌BERT横扫11项NLP任务记录
语言计算:序列标注前沿技术研究
大家知道,序列标注、文本分类、句对关系判断和生成式任务并称自然语言处理四大基础技术支柱。序列标注作为最基础的语言计算任务已在命名实体识别、词性标注、分词以及属性抽取等场景中得到了广泛的应用。这里顺便提一下,我们在属性抽取方面沉淀了诸多宝贵的经验,限于文章篇幅,本文将侧重序列标注理论的阐述,业务应用将在后续文章中体现。
腾讯云AI
2019/07/19
12K0
LLM主要类别架构
💫LLM分类一般分为三种:自编码模型(encoder)、自回归模型(decoder)和序列到序列模型(encoder-decoder)。
@小森
2024/06/04
4910
GPT、BERT、XLM、GPT-2、BART…你都掌握了吗?一文总结文本生成必备经典模型(二)
 机器之心专栏 本专栏由机器之心SOTA!模型资源站出品,每周日于机器之心公众号持续更新。 本专栏将逐一盘点自然语言处理、计算机视觉等领域下的常见任务,并对在这些任务上取得过 SOTA 的经典模型逐一详解。前往 SOTA!模型资源站(sota.jiqizhixin.com)即可获取本文中包含的模型实现代码、预训练模型及 API 等资源。 本文将分 2 期进行连载,共介绍 10 个在文本生成任务上曾取得 SOTA 的经典模型。 第 1 期:Seq2Seq(RNN)、Seq2Seq(LSTM)、Seq2Seq+
机器之心
2023/03/29
1.1K0
GPT、BERT、XLM、GPT-2、BART…你都掌握了吗?一文总结文本生成必备经典模型(二)
推荐阅读
相关推荐
《BERT基础教程:Transformer大模型实战》读书笔记
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档