json文件有啥用

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了json文件有啥用相关的知识,希望对你有一定的参考价值。

参考技术A

JSON 是一种数据格式。它本身是一串字符串,只是它有固定格式的字符串。

JSON(javascript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式。它基于 ECMAScript (欧洲计算机协会制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。



简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集。

JSON是Douglas Crockford在2001年开始推广使用的数据格式,在2005年-2006年正式成为主流的数据格式,雅虎和谷歌就在那时候开始广泛地使用JSON格式。

简单地说,JSON 可以将 JavaScript 对象中表示的一组数据转换为字符串,然后就可以在网络或者程序之间轻松地传递这个字符串,并在需要的时候将它还原为各编程语言所支持的数据格式,例如在 php 中,可以将 JSON 还原为数组或者一个基本对象。

在用到AJAX时,如果需要用到数组传值,这时就需要用JSON将数组转化为字符串。

Angular CLI 生成的“spec.ts”文件有啥用?

【中文标题】Angular CLI 生成的“spec.ts”文件有啥用?【英文标题】:What are the "spec.ts" files generated by Angular CLI for?Angular CLI 生成的“spec.ts”文件有什么用? 【发布时间】:2016-09-26 22:25:34 【问题描述】:

我是 Angular 2(以及一般的 Angular...)的新手,我发现它非常吸引人。我正在使用Angular CLI 来生成和服务项目。它似乎运作良好 - 尽管对于我的小型学习项目,它产生的结果超出了我的需要 - 但这是意料之中的。

我注意到它会为项目中的每个 Angular 元素(组件、服务、管道等)生成 spec.ts。我四处搜索,但没有找到这些文件的用途的解释。

这些构建文件在使用tsc 时通常是隐藏的吗?我想知道是因为我想更改我创建的名称很差的 Component 的名称,并发现这些 spec.ts 文件中也引用了该名称。


import 
  beforeEach,
  beforeEachProviders,
  describe,
  expect,
  it,
  inject,
 from '@angular/core/testing';
import  ComponentFixture, TestComponentBuilder  from '@angular/compiler/testing';
import  Component  from '@angular/core';
import  By  from '@angular/platform-browser';
import  PovLevelComponent  from './pov-level.component';

describe('Component: PovLevel', () => 
  let builder: TestComponentBuilder;

  beforeEachProviders(() => [PovLevelComponent]);
  beforeEach(inject([TestComponentBuilder], function (tcb: TestComponentBuilder) 
    builder = tcb;
  ));

  it('should inject the component', inject([PovLevelComponent],
      (component: PovLevelComponent) => 
    expect(component).toBeTruthy();
  ));

  it('should create the component', inject([], () => 
    return builder.createAsync(PovLevelComponentTestController)
      .then((fixture: ComponentFixture<any>) => 
        let query = fixture.debugElement.query(By.directive(PovLevelComponent));
        expect(query).toBeTruthy();
        expect(query.componentInstance).toBeTruthy();
      );
  ));
);

@Component(
  selector: 'test',
  template: `
    <app-pov-level></app-pov-level>
  `,
  directives: [PovLevelComponent]
)
class PovLevelComponentTestController 

【问题讨论】:

【参考方案1】:

规范文件是源文件的单元测试。 Angular 应用程序的约定是每个 .ts 文件都有一个 .spec.ts 文件。当您使用 ng test 命令时,它们通过 Karma 测试运行程序 (https://karma-runner.github.io/) 使用 Jasmine javascript 测试框架运行。

您可以使用它进行进一步阅读:

https://angular.io/guide/testing

【讨论】:

谢谢,我自己也在想这个。假设我不想运行任何测试,我可以安全地删除 .spec 文件吗? (还有测试文件夹和文件,例如 e2e 文件夹?) 我也觉得这个问题需要更多的回答。我们可以完全忽略这些文件并继续我们的工作吗? 正如 awiseman 所说,规范文件确实用于测试您的应用程序。如果您不想使用测试文件,您可以简单地删除或忽略它们。您的项目将在没有规范文件的情况下继续运行。 当您使用 CLI 生成新组件时,您可以添加 --spec=false 以排除规范文件的生成。生成新组件的完整命令是:ng g component comp-name --spec=false。更多信息在这里:github.com/angular/angular-cli/wiki/generate-component 这可以通过修改angular-cli.json来禁用: "defaults": "component": "spec": false 【参考方案2】:

如果您使用“ng new”生成新的 Angular 项目,您可以跳过 spec.ts 文件的生成。为此,您应该应用 --skip-tests 选项。

ng new ng-app-name --skip-tests

【讨论】:

项目生成后可以设置这个选项吗? @HughHughTeotl 是的,用于未来的服务生成,而不是已经生成的服务。如前所述:如果您不打算进行测试,您可以手动删除 spec.ts 文件。【参考方案3】:

.spec.ts 文件用于单个组件的单元测试。 您可以通过ng test 运行 Karma 任务运行程序。为了查看特定组件的单元测试用例的代码覆盖率,请运行ng test --code-coverage

【讨论】:

【参考方案4】:

.spec.ts 文件用于您的应用程序的unit testing

如果您不想生成它,只需在创建新的Component 时使用--spec=false。像这样

ng generate component --spec=false mycomponentName

【讨论】:

以上是关于json文件有啥用的主要内容,如果未能解决你的问题,请参考以下文章

Json.stringify() 有啥用,没有 stringify [重复]

stringify 有啥用,然后解析一个 JSON 对象

Json.NET 序列化回调中的 StreamingContext 参数有啥用?

bottle.post()python有啥用

PostgreSQL 中 JSONB[] (JSONB ARRAY) 数据类型有啥用?

Alamofire 的 .responseString 方法有啥用?