当前位置:Gxlcms > JavaScript > 详解js静态检查工具eslint配置文件

详解js静态检查工具eslint配置文件

时间:2021-07-01 10:21:17 帮助过:5人阅读

ESLint 是一个 Javascript 静态检查工具,它可以帮你养成良好的编程习惯

  1. {
  2. // 环境定义了预定义的全局变量。
  3. "env": {
  4. //环境定义了预定义的全局变量。更多在官网查看
  5. "browser": true,
  6. "node": true,
  7. "commonjs": true,
  8. "amd": true,
  9. "es6": true,
  10. "mocha": true
  11. },
  12. // JavaScript 语言选项
  13. "parserOptions": {
  14. // ECMAScript 版本
  15. "ecmaVersion": 6,
  16. "sourceType": "module", //设置为 "script" (默认) 或 "module"(如果你的代码是 ECMAScript 模块)。
  17. //想使用的额外的语言特性:
  18. "ecmaFeatures": {
  19. // 允许在全局作用域下使用 return 语句
  20. "globalReturn": true,
  21. // impliedStric
  22. "impliedStrict": true,
  23. // 启用 JSX
  24. "jsx": true,
  25. "modules": true
  26. }
  27. },
  28. //-----让eslint支持 JSX start
  29. "plugins": [
  30. "react"
  31. ],
  32. "extends": [
  33. "eslint:recommended",
  34. "plugin:react/recommended"
  35. ],
  36. //-----让eslint支持 JSX end
  37. /**
  38. * "off" 或 0 - 关闭规则
  39. * "warn" 或 1 - 开启规则,使用警告级别的错误:warn (不会导致程序退出),
  40. * "error" 或 2 - 开启规则,使用错误级别的错误:error (当被触发的时候,程序会退出)
  41. */
  42. "rules": {
  43. ////////////////
  44. // 可能的错误 //
  45. ////////////////
  46. // 禁止条件表达式中出现赋值操作符
  47. "no-cond-assign": 2,
  48. // 禁用 console
  49. "no-console": 0,
  50. // 禁止在条件中使用常量表达式
  51. // if (false) {
  52. // doSomethingUnfinished();
  53. // } //cuowu
  54. "no-constant-condition": 2,
  55. // 禁止在正则表达式中使用控制字符 :new RegExp("\x1f")
  56. "no-control-regex": 2,
  57. // 数组和对象键值对最后一个逗号, never参数:不能带末尾的逗号, always参数:必须带末尾的逗号,
  58. // always-multiline:多行模式必须带逗号,单行模式不能带逗号
  59. "comma-dangle": [1, "never"],
  60. // 禁用 debugger
  61. "no-debugger": 2,
  62. // 禁止 function 定义中出现重名参数
  63. "no-dupe-args": 2,
  64. // 禁止对象字面量中出现重复的 key
  65. "no-dupe-keys": 2,
  66. // 禁止重复的 case 标签
  67. "no-duplicate-case": 2,
  68. // 禁止空语句块
  69. "no-empty": 2,
  70. // 禁止在正则表达式中使用空字符集 (/^abc[]/)
  71. "no-empty-character-class": 2,
  72. // 禁止对 catch 子句的参数重新赋值
  73. "no-ex-assign": 2,
  74. // 禁止不必要的布尔转换
  75. "no-extra-boolean-cast": 2,
  76. // 禁止不必要的括号 //(a * b) + c;//报错
  77. "no-extra-parens": 0,
  78. // 禁止不必要的分号
  79. "no-extra-semi": 2,
  80. // 禁止对 function 声明重新赋值
  81. "no-func-assign": 2,
  82. // 禁止在嵌套的块中出现 function 或 var 声明
  83. "no-inner-declarations": [2, "functions"],
  84. // 禁止 RegExp 构造函数中无效的正则表达式字符串
  85. "no-invalid-regexp": 2,
  86. // 禁止在字符串和注释之外不规则的空白
  87. "no-irregular-whitespace": 2,
  88. // 禁止在 in 表达式中出现否定的左操作数
  89. "no-negated-in-lhs": 2,
  90. // 禁止把全局对象 (Math 和 JSON) 作为函数调用 错误:var math = Math();
  91. "no-obj-calls": 2,
  92. // 禁止直接使用 Object.prototypes 的内置属性
  93. "no-prototype-builtins": 0,
  94. // 禁止正则表达式字面量中出现多个空格
  95. "no-regex-spaces": 2,
  96. // 禁用稀疏数组
  97. "no-sparse-arrays": 2,
  98. // 禁止出现令人困惑的多行表达式
  99. "no-unexpected-multiline": 2,
  100. // 禁止在return、throw、continue 和 break语句之后出现不可达代码
  101. "no-unreachable": 2,
  102. // 要求使用 isNaN() 检查 NaN
  103. "use-isnan": 2,
  104. // 强制使用有效的 JSDoc 注释
  105. "valid-jsdoc": 1,
  106. // 强制 typeof 表达式与有效的字符串进行比较
  107. // typeof foo === "undefimed" 错误
  108. "valid-typeof": 2,
  109. //////////////
  110. // 最佳实践 //
  111. //////////////
  112. // 定义对象的set存取器属性时,强制定义get
  113. "accessor-pairs": 2,
  114. // 强制数组方法的回调函数中有 return 语句
  115. "array-callback-return": 0,
  116. // 强制把变量的使用限制在其定义的作用域范围内
  117. "block-scoped-var": 0,
  118. // 限制圈复杂度,也就是类似if else能连续接多少个
  119. "complexity": [2, 9],
  120. // 要求 return 语句要么总是指定返回的值,要么不指定
  121. "consistent-return": 0,
  122. // 强制所有控制语句使用一致的括号风格
  123. "curly": [2, "all"],
  124. // switch 语句强制 default 分支,也可添加 // no default 注释取消此次警告
  125. "default-case": 2,
  126. // 强制object.key 中 . 的位置,参数:
  127. // property,'.'号应与属性在同一行
  128. // object, '.' 号应与对象名在同一行
  129. "dot-location": [2, "property"],
  130. // 强制使用.号取属性
  131. // 参数: allowKeywords:true 使用保留字做属性名时,只能使用.方式取属性
  132. // false 使用保留字做属性名时, 只能使用[]方式取属性 e.g [2, {"allowKeywords": false}]
  133. // allowPattern: 当属性名匹配提供的正则表达式时,允许使用[]方式取值,否则只能用.号取值 e.g [2, {"allowPattern": "^[a-z]+(_[a-z]+)+$"}]
  134. "dot-notation": [2, {
  135. "allowKeywords": false
  136. }],
  137. // 使用 === 替代 == allow-null允许null和undefined==
  138. "eqeqeq": [2, "allow-null"],
  139. // 要求 for-in 循环中有一个 if 语句
  140. "guard-for-in": 2,
  141. // 禁用 alert、confirm 和 prompt
  142. "no-alert": 0,
  143. // 禁用 arguments.caller 或 arguments.callee
  144. "no-caller": 2,
  145. // 不允许在 case 子句中使用词法声明
  146. "no-case-declarations": 2,
  147. // 禁止除法操作符显式的出现在正则表达式开始的位置
  148. "no-div-regex": 2,
  149. // 禁止 if 语句中有 return 之后有 else
  150. "no-else-return": 0,
  151. // 禁止出现空函数.如果一个函数包含了一条注释,它将不会被认为有问题。
  152. "no-empty-function": 2,
  153. // 禁止使用空解构模式no-empty-pattern
  154. "no-empty-pattern": 2,
  155. // 禁止在没有类型检查操作符的情况下与 null 进行比较
  156. "no-eq-null": 1,
  157. // 禁用 eval()
  158. "no-eval": 2,
  159. // 禁止扩展原生类型
  160. "no-extend-native": 2,
  161. // 禁止不必要的 .bind() 调用
  162. "no-extra-bind": 2,
  163. // 禁用不必要的标签
  164. "no-extra-label:": 0,
  165. // 禁止 case 语句落空
  166. "no-fallthrough": 2,
  167. // 禁止数字字面量中使用前导和末尾小数点
  168. "no-floating-decimal": 2,
  169. // 禁止使用短符号进行类型转换(!!fOO)
  170. "no-implicit-coercion": 0,
  171. // 禁止在全局范围内使用 var 和命名的 function 声明
  172. "no-implicit-globals": 1,
  173. // 禁止使用类似 eval() 的方法
  174. "no-implied-eval": 2,
  175. // 禁止 this 关键字出现在类和类对象之外
  176. "no-invalid-this": 0,
  177. // 禁用 __iterator__ 属性
  178. "no-iterator": 2,
  179. // 禁用标签语句
  180. "no-labels": 2,
  181. // 禁用不必要的嵌套块
  182. "no-lone-blocks": 2,
  183. // 禁止在循环中出现 function 声明和表达式
  184. "no-loop-func": 1,
  185. // 禁用魔术数字(3.14什么的用常量代替)
  186. "no-magic-numbers": [1, {
  187. "ignore": [0, -1, 1]
  188. }],
  189. // 禁止使用多个空格
  190. "no-multi-spaces": 2,
  191. // 禁止使用多行字符串,在 JavaScript 中,可以在新行之前使用斜线创建多行字符串
  192. "no-multi-str": 2,
  193. // 禁止对原生对象赋值
  194. "no-native-reassign": 2,
  195. // 禁止在非赋值或条件语句中使用 new 操作符
  196. "no-new": 2,
  197. // 禁止对 Function 对象使用 new 操作符
  198. "no-new-func": 0,
  199. // 禁止对 String,Number 和 Boolean 使用 new 操作符
  200. "no-new-wrappers": 2,
  201. // 禁用八进制字面量
  202. "no-octal": 2,
  203. // 禁止在字符串中使用八进制转义序列
  204. "no-octal-escape": 2,
  205. // 不允许对 function 的参数进行重新赋值
  206. "no-param-reassign": 0,
  207. // 禁用 __proto__ 属性
  208. "no-proto": 2,
  209. // 禁止使用 var 多次声明同一变量
  210. "no-redeclare": 2,
  211. // 禁用指定的通过 require 加载的模块
  212. "no-return-assign": 0,
  213. // 禁止使用 javascript: url
  214. "no-script-url": 0,
  215. // 禁止自我赋值
  216. "no-self-assign": 2,
  217. // 禁止自身比较
  218. "no-self-compare": 2,
  219. // 禁用逗号操作符
  220. "no-sequences": 2,
  221. // 禁止抛出非异常字面量
  222. "no-throw-literal": 2,
  223. // 禁用一成不变的循环条件
  224. "no-unmodified-loop-condition": 2,
  225. // 禁止出现未使用过的表达式
  226. "no-unused-expressions": 0,
  227. // 禁用未使用过的标签
  228. "no-unused-labels": 2,
  229. // 禁止不必要的 .call() 和 .apply()
  230. "no-useless-call": 2,
  231. // 禁止不必要的字符串字面量或模板字面量的连接
  232. "no-useless-concat": 2,
  233. // 禁用不必要的转义字符
  234. "no-useless-escape": 0,
  235. // 禁用 void 操作符
  236. "no-void": 0,
  237. // 禁止在注释中使用特定的警告术语
  238. "no-warning-comments": 0,
  239. // 禁用 with 语句
  240. "no-with": 2,
  241. // 强制在parseInt()使用基数参数
  242. "radix": 2,
  243. // 要求所有的 var 声明出现在它们所在的作用域顶部
  244. "vars-on-top": 0,
  245. // 要求 IIFE 使用括号括起来
  246. "wrap-iife": [2, "any"],
  247. // 要求或禁止 “Yoda” 条件
  248. "yoda": [2, "never"],
  249. // 要求或禁止使用严格模式指令
  250. "strict": 0,
  251. //////////////
  252. // 变量声明 //
  253. //////////////
  254. // 要求或禁止 var 声明中的初始化(初值)
  255. "init-declarations": 0,
  256. // 不允许 catch 子句的参数与外层作用域中的变量同名
  257. "no-catch-shadow": 0,
  258. // 禁止删除变量
  259. "no-delete-var": 2,
  260. // 不允许标签与变量同名
  261. "no-label-var": 2,
  262. // 禁用特定的全局变量
  263. "no-restricted-globals": 0,
  264. // 禁止 var 声明 与外层作用域的变量同名
  265. "no-shadow": 0,
  266. // 禁止覆盖受限制的标识符
  267. "no-shadow-restricted-names": 2,
  268. // 禁用未声明的变量,除非它们在 /*global */ 注释中被提到
  269. "no-undef": 2,
  270. // 禁止将变量初始化为 undefined
  271. "no-undef-init": 2,
  272. // 禁止将 undefined 作为标识符
  273. "no-undefined": 0,
  274. // 禁止出现未使用过的变量
  275. "no-unused-vars": [2, {
  276. "vars": "all",
  277. "args": "none"
  278. }],
  279. // 不允许在变量定义之前使用它们
  280. "no-use-before-define": 0,
  281. //////////////////////////
  282. // Node.js and CommonJS //
  283. //////////////////////////
  284. // require return statements after callbacks
  285. "callback-return": 0,
  286. // 要求 require() 出现在顶层模块作用域中
  287. "global-require": 1,
  288. // 要求回调函数中有容错处理
  289. "handle-callback-err": [2, "^(err|error)$"],
  290. // 禁止混合常规 var 声明和 require 调用
  291. "no-mixed-requires": 0,
  292. // 禁止调用 require 时使用 new 操作符
  293. "no-new-require": 2,
  294. // 禁止对 __dirname 和 __filename进行字符串连接
  295. "no-path-concat": 0,
  296. // 禁用 process.env
  297. "no-process-env": 0,
  298. // 禁用 process.exit()
  299. "no-process-exit": 0,
  300. // 禁用同步方法
  301. "no-sync": 0,
  302. //////////////
  303. // 风格指南 //
  304. //////////////
  305. // 指定数组的元素之间要以空格隔开(, 后面), never参数:[ 之前和 ] 之后不能带空格,always参数:[ 之前和 ] 之后必须带空格
  306. "array-bracket-spacing": [2, "never"],
  307. // 禁止或强制在单行代码块中使用空格(禁用)
  308. "block-spacing": [1, "never"],
  309. //强制使用一致的缩进 第二个参数为 "tab" 时,会使用tab,
  310. // if while function 后面的{必须与if在同一行,java风格。
  311. "brace-style": [2, "1tbs", {
  312. "allowSingleLine": true
  313. }],
  314. // 双峰驼命名格式
  315. "camelcase": 2,
  316. // 控制逗号前后的空格
  317. "comma-spacing": [2, {
  318. "before": false,
  319. "after": true
  320. }],
  321. // 控制逗号在行尾出现还是在行首出现 (默认行尾)
  322. // http://eslint.org/docs/rules/comma-style
  323. "comma-style": [2, "last"],
  324. //"SwitchCase" (默认:0) 强制 switch 语句中的 case 子句的缩进水平
  325. // 以方括号取对象属性时,[ 后面和 ] 前面是否需要空格, 可选参数 never, always
  326. "computed-property-spacing": [2, "never"],
  327. // 用于指统一在回调函数中指向this的变量名,箭头函数中的this已经可以指向外层调用者,应该没卵用了
  328. // e.g [0,"that"] 指定只能 var that = this. that不能指向其他任何值,this也不能赋值给that以外的其他值
  329. "consistent-this": [1, "that"],
  330. // 强制使用命名的 function 表达式
  331. "func-names": 0,
  332. // 文件末尾强制换行
  333. "eol-last": 2,
  334. "indent": [2, 4, {
  335. "SwitchCase": 1
  336. }],
  337. // 强制在对象字面量的属性中键和值之间使用一致的间距
  338. "key-spacing": [2, {
  339. "beforeColon": false,
  340. "afterColon": true
  341. }],
  342. // 强制使用一致的换行风格
  343. "linebreak-style": [1, "unix"],
  344. // 要求在注释周围有空行 ( 要求在块级注释之前有一空行)
  345. "lines-around-comment": [1, {
  346. "beforeBlockComment": true
  347. }],
  348. // 强制一致地使用函数声明或函数表达式,方法定义风格,参数:
  349. // declaration: 强制使用方法声明的方式,function f(){} e.g [2, "declaration"]
  350. // expression:强制使用方法表达式的方式,var f = function() {} e.g [2, "expression"]
  351. // allowArrowFunctions: declaration风格中允许箭头函数。 e.g [2, "declaration", { "allowArrowFunctions": true }]
  352. "func-style": 0,
  353. // 强制回调函数最大嵌套深度 5层
  354. "max-nested-callbacks": [1, 5],
  355. // 禁止使用指定的标识符
  356. "id-blacklist": 0,
  357. // 强制标识符的最新和最大长度
  358. "id-length": 0,
  359. // 要求标识符匹配一个指定的正则表达式
  360. "id-match": 0,
  361. // 强制在 JSX 属性中一致地使用双引号或单引号
  362. "jsx-quotes": 0,
  363. // 强制在关键字前后使用一致的空格 (前后腰需要)
  364. "keyword-spacing": 2,
  365. // 强制一行的最大长度
  366. "max-len": [1, 200],
  367. // 强制最大行数
  368. "max-lines": 0,
  369. // 强制 function 定义中最多允许的参数数量
  370. "max-params": [1, 7],
  371. // 强制 function 块最多允许的的语句数量
  372. "max-statements": [1, 200],
  373. // 强制每一行中所允许的最大语句数量
  374. "max-statements-per-line": 0,
  375. // 要求构造函数首字母大写 (要求调用 new 操作符时有首字母大小的函数,允许调用首字母大写的函数时没有 new 操作符。)
  376. "new-cap": [2, {
  377. "newIsCap": true,
  378. "capIsNew": false
  379. }],
  380. // 要求调用无参构造函数时有圆括号
  381. "new-parens": 2,
  382. // 要求或禁止 var 声明语句后有一行空行
  383. "newline-after-var": 0,
  384. // 禁止使用 Array 构造函数
  385. "no-array-constructor": 2,
  386. // 禁用按位运算符
  387. "no-bitwise": 0,
  388. // 要求 return 语句之前有一空行
  389. "newline-before-return": 0,
  390. // 要求方法链中每个调用都有一个换行符
  391. "newline-per-chained-call": 1,
  392. // 禁用 continue 语句
  393. "no-continue": 0,
  394. // 禁止在代码行后使用内联注释
  395. "no-inline-comments": 0,
  396. // 禁止 if 作为唯一的语句出现在 else 语句中
  397. "no-lonely-if": 0,
  398. // 禁止混合使用不同的操作符
  399. "no-mixed-operators": 0,
  400. // 不允许空格和 tab 混合缩进
  401. "no-mixed-spaces-and-tabs": 2,
  402. // 不允许多个空行
  403. "no-multiple-empty-lines": [2, {
  404. "max": 2
  405. }],
  406. // 不允许否定的表达式
  407. "no-negated-condition": 0,
  408. // 不允许使用嵌套的三元表达式
  409. "no-nested-ternary": 0,
  410. // 禁止使用 Object 的构造函数
  411. "no-new-object": 2,
  412. // 禁止使用一元操作符 ++ 和 --
  413. "no-plusplus": 0,
  414. // 禁止使用特定的语法
  415. "no-restricted-syntax": 0,
  416. // 禁止 function 标识符和括号之间出现空格
  417. "no-spaced-func": 2,
  418. // 不允许使用三元操作符
  419. "no-ternary": 0,
  420. // 禁用行尾空格
  421. "no-trailing-spaces": 2,
  422. // 禁止标识符中有悬空下划线_bar
  423. "no-underscore-dangle": 0,
  424. // 禁止可以在有更简单的可替代的表达式时使用三元操作符
  425. "no-unneeded-ternary": 2,
  426. // 禁止属性前有空白
  427. "no-whitespace-before-property": 0,
  428. // 强制花括号内换行符的一致性
  429. "object-curly-newline": 0,
  430. // 强制在花括号中使用一致的空格
  431. "object-curly-spacing": 0,
  432. // 强制将对象的属性放在不同的行上
  433. "object-property-newline": 0,
  434. // 强制函数中的变量要么一起声明要么分开声明
  435. "one-var": [2, {
  436. "initialized": "never"
  437. }],
  438. // 要求或禁止在 var 声明周围换行
  439. "one-var-declaration-per-line": 0,
  440. // 要求或禁止在可能的情况下要求使用简化的赋值操作符
  441. "operator-assignment": 0,
  442. // 强制操作符使用一致的换行符
  443. "operator-linebreak": [2, "after", {
  444. "overrides": {
  445. "?": "before",
  446. ":": "before"
  447. }
  448. }],
  449. // 要求或禁止块内填充
  450. "padded-blocks": 0,
  451. // 要求对象字面量属性名称用引号括起来
  452. "quote-props": 0,
  453. // 强制使用一致的反勾号、双引号或单引号
  454. "quotes": [2, "double", "avoid-escape"],
  455. // 要求使用 JSDoc 注释
  456. "require-jsdoc": 1,
  457. // 要求或禁止使用分号而不是 ASI(这个才是控制行尾部分号的,)
  458. "semi": [2, "always"],
  459. // 强制分号之前和之后使用一致的空格
  460. "semi-spacing": 0,
  461. // 要求同一个声明块中的变量按顺序排列
  462. "sort-vars": 0,
  463. // 强制在块之前使用一致的空格
  464. "space-before-blocks": [2, "always"],
  465. // 强制在 function的左括号之前使用一致的空格
  466. "space-before-function-paren": [0, "always"],
  467. // 强制在圆括号内使用一致的空格
  468. "space-in-parens": [2, "never"],
  469. // 要求操作符周围有空格
  470. "space-infix-ops": 2,
  471. // 强制在一元操作符前后使用一致的空格
  472. "space-unary-ops": [2, {
  473. "words": true,
  474. "nonwords": false
  475. }],
  476. // 强制在注释中 // 或 /* 使用一致的空格
  477. "spaced-comment": [2, "always", {
  478. "markers": ["global", "globals", "eslint", "eslint-disable", "*package", "!"]
  479. }],
  480. // 要求或禁止 Unicode BOM
  481. "unicode-bom": 0,
  482. // 要求正则表达式被括号括起来
  483. "wrap-regex": 0,
  484. //////////////
  485. // ES6.相关 //
  486. //////////////
  487. // 要求箭头函数体使用大括号
  488. "arrow-body-style": 2,
  489. // 要求箭头函数的参数使用圆括号
  490. "arrow-parens": 2,
  491. "arrow-spacing": [2, {
  492. "before": true,
  493. "after": true
  494. }],
  495. // 强制在子类构造函数中用super()调用父类构造函数,TypeScrip的编译器也会提示
  496. "constructor-super": 0,
  497. // 强制 generator 函数中 * 号周围使用一致的空格
  498. "generator-star-spacing": [2, {
  499. "before": true,
  500. "after": true
  501. }],
  502. // 禁止修改类声明的变量
  503. "no-class-assign": 2,
  504. // 不允许箭头功能,在那里他们可以混淆的比较
  505. "no-confusing-arrow": 0,
  506. // 禁止修改 const 声明的变量
  507. "no-const-assign": 2,
  508. // 禁止类成员中出现重复的名称
  509. "no-dupe-class-members": 2,
  510. // 不允许复制模块的进口
  511. "no-duplicate-imports": 0,
  512. // 禁止 Symbol 的构造函数
  513. "no-new-symbol": 2,
  514. // 允许指定模块加载时的进口
  515. "no-restricted-imports": 0,
  516. // 禁止在构造函数中,在调用 super() 之前使用 this 或 super
  517. "no-this-before-super": 2,
  518. // 禁止不必要的计算性能键对象的文字
  519. "no-useless-computed-key": 0,
  520. // 要求使用 let 或 const 而不是 var
  521. "no-var": 0,
  522. // 要求或禁止对象字面量中方法和属性使用简写语法
  523. "object-shorthand": 0,
  524. // 要求使用箭头函数作为回调
  525. "prefer-arrow-callback": 0,
  526. // 要求使用 const 声明那些声明后不再被修改的变量
  527. "prefer-const": 0,
  528. // 要求在合适的地方使用 Reflect 方法
  529. "prefer-reflect": 0,
  530. // 要求使用扩展运算符而非 .apply()
  531. "prefer-spread": 0,
  532. // 要求使用模板字面量而非字符串连接
  533. "prefer-template": 0,
  534. // Suggest using the rest parameters instead of arguments
  535. "prefer-rest-params": 0,
  536. // 要求generator 函数内有 yield
  537. "require-yield": 0,
  538. // enforce spacing between rest and spread operators and their expressions
  539. "rest-spread-spacing": 0,
  540. // 强制模块内的 import 排序
  541. "sort-imports": 0,
  542. // 要求或禁止模板字符串中的嵌入表达式周围空格的使用
  543. "template-curly-spacing": 1,
  544. // 强制在 yield* 表达式中 * 周围使用空格
  545. "yield-star-spacing": 2
  546. }
  547. }

总结

以上所述是小编给大家介绍的js静态检查工具eslint配置文件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

人气教程排行