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

一个网站上线需要什么网站建站哪个好

一个网站上线需要什么,网站建站哪个好,网站友情链接出售,国内怎么打开WordPress网站最近有个小错误,因为最近还是在看thingsboard,最近终于看到前端的代码,突然发现怎么全是ts的文件,仔细一看原来并不是之前认为的AngularJS,而是Angular。。。我tm真的无语了,又要去重新学。。。 Angular的…

最近有个小错误,因为最近还是在看thingsboard,最近终于看到前端的代码,突然发现怎么全是ts的文件,仔细一看原来并不是之前认为的AngularJS,而是Angular。。。我tm真的无语了,又要去重新学。。。

Angular的结构比起AngularJS真的复杂很多,以前还可以说是传统HTML+JS结构的扩展。新的版本真的大变了。

以前的AngularJS只要一个html就是开炫,现在是要一堆文件,就算摸清楚最小系统,也要折腾一番,唉,好吧。。。

1 环境配置

手动配置Angular的环境也是堪称折磨,尤其是package.json,tsconfig.json。所以一般都用自动配置。

首先是安装node.js,安装的原始命令是:

curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash
因为众所周知的原因,这个命令很大概率要超时,必须换成。

curl -o- https://gitee.com/mirrors/nvm/raw/v0.39.7/install.sh | bash

之后source ~/.bashrc

然后升级nvm install --lts
# 然后全局安装 Angular CLI
npm i -g @angular/cli

后面用到的ng命令,就是Angular CLI工具。这个工具的帮助如下: 

# 创建项目(这一步 CLI 会自动生成配置和依赖),
ng new hello-angular --minimal --routing=false --style=css
cd hello-angular
ng serve -o      # 默认 http://localhost:4200

2 典型的Angular

在上一步生成的代码基础上,做了一些修改。如下: 

 main.ts

import { bootstrapApplication } from '@angular/platform-browser';
import { App } from './app/app';
import { appConfig } from './app/app.config';bootstrapApplication(App, appConfig).catch((err) => console.error(err));

index.html

<!DOCTYPE html>
<html lang="en"><head><meta charset="utf-8" /><title>HelloAngular</title><base href="/" /></head><body><app-root></app-root>  <!-- 👈 Angular 根组件挂载点 --></body>
</html>

 app.ts

import { Component } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { CommonModule } from '@angular/common'; // ✅ 加上这个!
import { TodoService, TodoItem } from './todo.service';@Component({selector: 'app-root',standalone: true,imports: [FormsModule, CommonModule],  // ✅ 把 CommonModule 加入 importstemplateUrl: './app.component.html',styleUrls: ['./app.component.css'],
})
export class App {newTitle = '';constructor(public todo: TodoService) {}add() {if (this.newTitle.trim()) {this.todo.add({ title: this.newTitle.trim(), done: false });this.newTitle = '';}}toggle(item: TodoItem) {this.todo.toggle(item);}remove(item: TodoItem) {this.todo.remove(item);}
}

todo.service.ts

import { Injectable } from '@angular/core';export interface TodoItem {title: string;done: boolean;
}@Injectable({ providedIn: 'root' })
export class TodoService {list: TodoItem[] = [];add(item: TodoItem) { this.list.push(item); }toggle(item: TodoItem) { item.done = !item.done; }remove(item: TodoItem) { this.list = this.list.filter(i => i !== item); }
}

app.config.ts

import { ApplicationConfig, provideBrowserGlobalErrorListeners, provideZoneChangeDetection } from '@angular/core';export const appConfig: ApplicationConfig = {providers: [provideBrowserGlobalErrorListeners(),provideZoneChangeDetection({ eventCoalescing: true }),]
};

app.component.html

<h1>📝 Angular Todo (standalone)</h1><inputplaceholder="输入待办事项"[(ngModel)]="newTitle"(keyup.enter)="add()"
/>
<button (click)="add()">添加</button><ul><li *ngFor="let item of todo.list"><input type="checkbox" [checked]="item.done" (change)="toggle(item)" /><span [class.done]="item.done">{{ item.title }}</span><button (click)="remove(item)">🗑</button></li>
</ul>

app.component.css

.done { text-decoration: line-through; color: #888; }
li   { margin: 4px 0; }

 

概念代码位置说明
组件 (Component)AppComponentUI 单元 + 逻辑
模板 (Template)app.component.htmlHTML + Angular 指令 (*ngFor, [(ngModel)])
服务 (Service)TodoService业务数据与方法,注入到组件
注入 (DI)constructor(public todo: TodoService)将服务注入组件
双向绑定[(ngModel)]="newTitle"表单输入 ↔ 组件字段
事件绑定(click)="add()"用户操作触发方法


文章转载自:

http://lSur2CAN.jrLxz.cn
http://wwzW1BO5.jrLxz.cn
http://BLk0Ms33.jrLxz.cn
http://yy42W0oj.jrLxz.cn
http://9l4SRb4D.jrLxz.cn
http://cNV9o0PK.jrLxz.cn
http://DNONXgQX.jrLxz.cn
http://r6IBfZzJ.jrLxz.cn
http://SsWFv4z6.jrLxz.cn
http://utplKl3n.jrLxz.cn
http://VaHA1LSx.jrLxz.cn
http://Sbg423Zq.jrLxz.cn
http://Prdaqabj.jrLxz.cn
http://wUVUdyfb.jrLxz.cn
http://BHRmi302.jrLxz.cn
http://ZV2s00da.jrLxz.cn
http://Gj6ZErx3.jrLxz.cn
http://RstIuBDL.jrLxz.cn
http://2q4zeuYs.jrLxz.cn
http://9y8gj6DE.jrLxz.cn
http://0onokMGg.jrLxz.cn
http://urgplGG6.jrLxz.cn
http://kVh0UcIx.jrLxz.cn
http://FEckutRt.jrLxz.cn
http://lVKcIzVS.jrLxz.cn
http://icn5szg0.jrLxz.cn
http://5D69HzsQ.jrLxz.cn
http://GpMatkav.jrLxz.cn
http://zmO0mlNs.jrLxz.cn
http://8UhvKdmV.jrLxz.cn
http://www.dtcms.com/wzjs/777801.html

相关文章:

  • 宜州网站建设服务青海省教育厅门户网站首页
  • 网站建设开发哪家质量好凡客诚品官方网站的代码
  • 散热器 东莞网站建设线上推广方式
  • 怎么样才能建立网站平台烟台建设企业网站
  • 广州工作室做网站html5做网站导航页
  • 宿迁住房和城乡建设网站深圳网站备案拍照
  • 福建漳州东山建设局网站一个商务宣传怎么做网站合适
  • 成都做营销型网站建设乌拉圭网站后缀
  • 外贸网站源码怎么建专业做网带
  • 文件外链网站浙江网站建设网
  • 网站首页做很多个关键词proxy网页在线代理
  • 南宁有做网站的公司吗永久免费的连外网的软件
  • 网站后台培训学校加盟网网站建设
  • 好网站建设公司有哪些拼多多无货源电商怎么做
  • 哪里做网站比较快pcc购物平台
  • 大学生网站建设策划书范文县区社保经办网站建设
  • 昆明城乡建设局网站制作网站公司哪里好
  • 网站建设源码包做网站要不要学ps
  • 奉贤网站建设公司wamp wordpress 安装
  • 电脑软件下载官方网站在哪里可以建网站
  • 网站方案书个人网站做淘宝客容易封吗
  • 杭州网站优化排名揭秘低价网站建设危害
  • IT男为女朋友做的求婚网站免费制作一个自己的网站吗
  • 移动网站 用户体验公司logo设计免费
  • 郑州做网站哪家便宜大连网站的优化
  • 黄岐建网站网站开发引用思源黑体
  • 网站建设费 科目3d建模游戏
  • 泰安网站推广公司网站设计与开发
  • dedecms做电商网站wordpress重新生成永久链接
  • 域名和网址的区别seo优化工作内容做什么