独学プログラミング演習
テキスト | 日付 | 進捗状況 |
---|---|---|
Angularアプリケーションプログラミング | 2023/09/23 | finished ->コード |
モダンJavaScriptの基本から始めるReact実践の教科書 | 2022/07/02 | finished ->コード |
コンテンツ | 日付 | 進捗状況 |
---|---|---|
Vercel+Next.jsを活用したWebアプリケーション開発入門 | 2022/11/03 | 第4回 ブログを作りながら学ぶ、Next.jsの便利な4つの機能(グローバル設定、プリレンダリング、動的ルート、サーバーレス) |
TypeScriptで学ぶJavaScriptフレームワーク「Vue.js」の利用法 | 2024/05/22 | 第8回 TypeScriptとも相性抜群なライブラリ──Vue.jsで状態管理を行う新定番「Pinia」を解説! finished |
ホスティング・サービス
ホスト | FW | 最終更新 |
---|---|---|
Vercel | Next.js 15.1.3 | 2024/12/28 |
Astro 5.1.1 | 2024/12/28 |
Windows
端末 | FW | 最終更新 |
---|---|---|
Windows | Node.js 22.12.0 | 2024/12/11 |
Bun 1.1.43 | 2025/01/11 | |
Vite 6.0.7 | 2025/01/05 | |
React 19.0.0 | 2024/12/12 | |
- Bun 1.1.38 | 2024/11/29 | |
Astro 5.1.3 | 2025/01/07 | |
- Bun 1.1.42 | 2024/12/31 | |
- React 19.0.0 | 2024/12/11 | |
Next.js 15.1.3 | 2025/01/07 | |
- React 19.0.0 | 2024/12/11 | |
- Bun 1.1.42 | 2024/12/31 | |
Nuxt 3.15.1 | 2025/01/07 | |
Vue 3.5.13 | 2024/11/29 | |
- Deno 2.1.2 | 2024/11/30 | |
- Vite 6.0.1 | 2024/11/29 | |
- Bun 1.1.38 | 2024/11/29 | |
Deno 2.1.2 | 2024/11/30 | |
- fresh 1.7.3 | 2024/10/26 | |
React Native 0.76.3 | 2024/12/04 | |
React Native Windows 0.76.2 | 2024/12/04 | |
- Windows SDK 10.0.22621 | 2024/12/04 | |
- Bun 1.1.38 | 2024/11/29 | |
Svelte 5.17.3 | 2025/01/11 | |
- Bun 1.1.43 | 2025/01/11 | |
- Vite 6.0.7 | 2025/01/05 | |
InsiderDev | Node.js 22.12.0 | 2024/12/14 |
Angular 19.0.5 | 2024/12/19 |
npm install --save "@xxx"
npm config set scripts-prepend-node-path true
powershell -c "irm bun.sh/install.ps1 | iex"
curl -fsSL https://bun.sh/install | bash
sudo apt install unzip
bun run
bun upgrade
Windows
iwr https://deno.land/install.ps1 -useb | iex
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0
0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0
100 32.4M 100 32.4M 0 0 15.0M 0 0:00:02 0:00:02 --:--:-- 57.0M
Deno was installed successfully to C:\Users\taish\.deno\bin\deno.exe
Run 'deno --help' to get started
Stuck? Join our Discord https://discord.gg/deno
Chrome OS Flex
curl -fsSL https://deno.land/x/install/install.sh | sh
deno upgrade
deno run -A -r https://fresh.deno.dev my-project
cd my-project
deno task start
deno run -Ar https://fresh.deno.dev/update
npx prisma studio
Environment variables loaded from .env
Prisma schema loaded from prisma\schema.prisma
Prisma Studio is up on http://localhost:5555
<Android SDKインストールディレクトリ>\emulator\emulator.exe -avd Nexus_5X_API_29_x86
react-native run-android
npx react-native init <projectName>
cd projectName
npx react-native-windows-init --overwrite
npx react-native run-windows
Upgrade
npx @astrojs/upgrade beta
Need to install the following packages:
@astrojs/upgrade@0.3.3
Ok to proceed? (y) y
astro Integration upgrade in progress.
● @astrojs/check will be updated to v0.9.4
● @astrojs/react will be updated to v
▲ astro will be updated to v5.0.0-beta.3
wait One package has breaking changes. Continue?
Yes
check Be sure to follow the CHANGELOG.
astro https://github.com/withastro/astro/blob/next/packages/astro/CHANGELOG.md#500-beta3
██████ Installing dependencies with bun...
+—————+ Houston:
| ^ u ^ Have fun building!
+—————+
Upgrade
npx @astrojs/upgrade
Need to install the following packages:
@astrojs/upgrade@0.2.2
Ok to proceed? (y) y
astro Integration upgrade in progress.
◼ @astrojs/react is up to date on v3.0.9
● astro will be updated to v4.2.1
● @astrojs/check will be updated to v0.4.1
✔ Installed dependencies!
╭─────╮ Houston:
│ ◠ ◡ ◠ See you around, astronaut.
╰─────╯
npm notice
npm notice New major version of npm available! 9.6.7 -> 10.3.0
npm notice Changelog: https://github.com/npm/cli/releases/tag/v10.3.0
npm notice Run npm install -g npm@10.3.0 to update!
npm notice
https://docs.astro.build/en/recipes/bun/#_top
npx create-next-app nextjs-blog --use-npm --example "https://github.com/vercel/next-learn/tree/master/basics/learn-starter"
git remote add origin https://github.com/Tatsukiyoshi/nextjs-blog.git
git push -u origin main
bun create next-app
npx create-next-app nextjs13-sample --ts --experimental-app --use-npm
(参考)Next.js 13 で開発方法はどう変わる?
npx create-next-app --ts --example with-turbopack
bun update v1.1.38 (bf2f153f)
⚙️ node-sass [1/6] node:internal/child_process:420
throw new ErrnoException(err, 'spawn');
^
Error: spawn EINVAL
at ChildProcess.spawn (node:internal/child_process:420:11)
at Object.spawn (node:child_process:753:9)
at build (D:\Repository\Weekend_Programming\js\react\practice\4-6\my-app\node_modules\fibers\build.js:62:5)
at Object.<anonymous> (D:\Repository\Weekend_Programming\js\react\practice\4-6\my-app\node_modules\fibers\build.js:51:3)
at Module._compile (node:internal/modules/cjs/loader:1565:14)
at Object..js (node:internal/modules/cjs/loader:1708:10)
at Module.load (node:internal/modules/cjs/loader:1318:32)
at Function._load (node:internal/modules/cjs/loader:1128:12)
at TracingChannel.traceSync (node:diagnostics_channel:322:14)
at wrapModuleLoad (node:internal/modules/cjs/loader:219:24) {
errno: -4071,
code: 'EINVAL',
syscall: 'spawn'
}
Node.js v22.12.0
bun: command not found: nodejs
error: install script from "fibers" exited with 1
Install
npm install react@rc react-dom@rc
Update package.json for using typescript
{
"dependencies": {
...
"@types/react": "npm:types-react@rc",
"@types/react-dom": "npm:types-react-dom@rc"
...
},
"overrides": {
"@types/react": "npm:types-react@rc",
"@types/react-dom": "npm:types-react-dom@rc"
}
}
Migration
npx codemod@latest react/19/migration-recipe
bun add update-browserslist-db@latest
bun create vite <Project Name>
bun install @silevis/reactgrid
bun create vite <Project Name>
bun add chart.js react-chartjs-2
"scripts": {
"build": "rollup -c",
"dev": "rollup -c -w",
"start": "sirv public --no-clear --port 8083",
"check": "svelte-check --tsconfig ./tsconfig.json",
"tauri": "tauri"
},
ノウハウ
コマンド
Commands:
Command | |
---|---|
ng analytics | Configures the gathering of Angular CLI usage metrics. <BR>See https://angular.io/cli/usage-analytics-gathering |
ng completion | Set up Angular CLI autocompletion for your terminal. |
ng config [json-path] [value] | Retrieves or sets Angular configuration values in the angular.json file for the workspace. |
ng doc <keyword> | Opens the official Angular documentation (angular.io) in a browser, and searches for a given keyword. [aliases: d] |
ng new [name] | Creates a new Angular workspace. [aliases: n] |
ng version | Outputs Angular CLI version. [aliases: v] |
Options:
--help | Shows a help message for this command in the console. [boolean] |
The above commands are available when running the Angular CLI outside a workspace.More commands are available when running inside a workspace. For more information, see https://angular.io/cli/.
Quick Start
git clone https://github.com/angular/quickstart.git
Angular 19対応
Component | Version |
---|---|
angular-in-memory-web-api | 0.19.0 |
rxjs | 7.8.1 |
tslib | 2.8.1 |
zone.js | 0.15.0 |
@types/jasmine | 5.1.5 |
jasmine-core | 5.5.0 |
karma | 6.4.4 |
karma-chrome-launcher | 3.2.0 |
karma-coverage | 2.2.1 |
karma-jasmine | 5.1.0 |
ng generate @angular/core:standalone
import { FormsModule } from '@angular/forms';
@Component({
imports: [FormsModule],
...
})
<input id="name" name="name" type="text" autocomplete="additional-name" [(ngModel)]="myName" />
import { CommonModule } from '@angular/common';
@Component({
imports: [CommonModule],
...
})
<li></li>
<div [ngClass]="styles">
<tr *ngFor="let b of books">
import { FormGroup, FormControl,
FormBuilder, Validators,
ReactiveFormsModule} from '@angular/forms'
@Component({
imports: [CommonModule, ReactiveFormsModule],
...
})
import { Component } from '@angular/core';
import { RouterModule } from '@angular/router';
@Component({
imports: [RouterModule],
...
})
import { FormsModule } from '@angular/forms';
@Component({
imports: [FormsModule],
...
})
import { Component } from '@angular/core';
@Component({
imports: [CommonModule],
...
})
Angular 18対応
ng update @angular/core@18 @angular/cli@18
[formControl]="$any(myForm).controls['mail']"
"dependencies": {
...
"angular-in-memory-web-api": "^0.18.0",
...
},
Angular 17対応
ライブラリ | バージョン |
---|---|
zone.js | 0.14.0 |
typescript | 5.2.2 |
Angular 16対応
"architect": {
"build": {
"builder": "@angular-devkit/build-angular:browser-esbuild",
}
}
ライブラリ | バージョン |
---|---|
zone.js | 0.13.0 |
typescript | 4.9.3 |
Angular 15対応
ライブラリ | バージョン |
---|---|
zone.js | 0.12.0 |
@types/jasmine | 4.3.0 |
jasmine-core | 4.5.0 |
karma | 6.4.0 |
karma-chrome-launcher | 3.1.0 |
karma-coverage | 2.2.0 |
karma-jasmine | 5.1.0 |
karma-jasmine-html-reporter | 2.0.0 |
typescript | 4.8.2 |
"target": "es2020",
TypeScript compiler options "target" and "useDefineForClassFields" are set to "ES2022" and "false" respectively by the Angular CLI. To control ECMA version and features use the Browerslist configuration. For more information, see https://angular.io/guide/build#configuring-browser-compatibility
"i18n": {
"locales": {
"ja": {
"translation": "src/locale/messages.ja.xlf"
}
}
}
"build": {
"builder": "@angular-devkit/build-angular:browser",
"options": {
"localize": true,
...
},
"configurations": {
"ja": {
"localize": ["ja"]
},
}
}
"serve": {
"builder": "@angular-devkit/build-angular:dev-server",
"configurations": {
"ja": {
"browserTarget": "i18n:build:development,ja"
},
}
}
ng serve -c "ja"
in-memory-web-api
rxjs
Karma + Jasmine
npm WARN EBADENGINE Unsupported engine {
npm WARN EBADENGINE package: 'karma@1.7.1',
npm WARN EBADENGINE required: { node: '0.10 || 0.12 || 4 || 5 || 6 || 7 || 8' },
npm WARN EBADENGINE current: { node: 'v16.15.0', npm: '8.5.5' }
npm WARN EBADENGINE }
npm WARN EBADENGINE Unsupported engine {
npm WARN EBADENGINE package: 'karma-cli@1.0.1',
npm WARN EBADENGINE required: { node: '0.10 || 0.12 || 4 || 5 || 6' },
npm WARN EBADENGINE current: { node: 'v16.15.0', npm: '8.5.5' }
npm WARN EBADENGINE }
npm WARN deprecated source-map-url@0.4.1: See https://github.com/lydell/source-map-url#deprecated
npm WARN deprecated urix@0.1.0: Please see https://github.com/lydell/urix#deprecated
npm WARN deprecated har-validator@5.1.5: this library is no longer supported
npm WARN deprecated json3@3.3.2: Please use the native JSON object instead of JSON 3
npm WARN deprecated chokidar@1.7.0: Chokidar 2 will break on node v14+. Upgrade to chokidar 3 with 15x less dependencies.
npm WARN deprecated source-map-resolve@0.5.3: See https://github.com/lydell/source-map-resolve#deprecated
npm WARN deprecated resolve-url@0.2.1: https://github.com/lydell/resolve-url#deprecated
npm WARN deprecated minimatch@0.3.0: Please update to minimatch 3.0.2 or higher to avoid a RegExp DoS issue
npm WARN deprecated uuid@3.4.0: Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details.
npm WARN deprecated request@2.88.2: request has been deprecated, see https://github.com/request/request/issues/3142
npm WARN deprecated @angular/http@4.3.6: Package no longer supported. Use @angular/common instead, see https://angular.io/guide/deprecations#angularhttp
npm WARN deprecated core-js@2.6.12: core-js@<3.4 is no longer maintained and not recommended for usage due to the number of issues. Because of the V8 engine whims, feature detection in old core-js versions could cause a slowdown up to 100x even if nothing is polyfilled. Please, upgrade your dependencies to the actual version of core-js.
PS D:\Repository\Tatsukiyoshi\Weekend_Programming\js\angular\quickstart> npm run build
> agular-quickstart@1.0.0 build
> tsc -p src/
node_modules/@types/component-emitter/index.d.ts(8,25): error TS1005: ',' expected.
node_modules/@types/cors/index.d.ts(41,52): error TS1005: ',' expected.
node_modules/@types/cors/index.d.ts(47,44): error TS1005: ',' expected.
node_modules/@types/cors/index.d.ts(47,47): error TS1005: ',' expected.
node_modules/@types/node/index.d.ts(20,1): error TS1084: Invalid 'reference' directive syntax.
error TS4111: Property 'minlength' comes from an index signature, so it must be accessed with ['minlength'].
<span *ngIf="mail.errors?.required">メールアドレスは必須です。</span>
<span *ngIf="mail.errors?.['required']">メールアドレスは必須です。</span>
npm install -g @angular/xxx
> ng build
You seem to not be depending on "@angular/core" and/or "rxjs". This is an error.
> npm update @angular/core
npm install -g webpack-dev-server
> npm install -g webpack
>npm cache clean
npm ERR! As of npm@5, the npm cache self-heals from corruption issues and data extracted from the cache is guaranteed to be valid. If you want to make sure everything is consistent, use 'npm cache verify' instead. On the other hand, if you're debugging an issue with the installer, you can use `npm install --cache /tmp/empty-cache` to use a temporary cache instead of nuking the actual one.
npm ERR!
npm ERR! If you're sure you want to delete the entire cache, rerun this command with --force.
npm ERR! A complete log of this run can be found in:
npm ERR! C:\Users\taish\AppData\Roaming\npm-cache\_logs\2019-06-23T06_53_10_230Z-debug.log
>npm\ cache clean --force
npm WARN using --force I sure hope you know what you are doing.
[..................] / : WARN using --force I sure hope you know what you are doing.
> npm install -g http-server
> http-server .\dist\vs-angular -p3000 -c-1 -o
vs-angular
basic_20190223
npm install --save-dev typescript
npm install -g @vue/cli
vue create <プロジェクト名>
npm init vite@latest
$ deno run -A npm:create-vite-extra --template deno-vue
npx create-nuxt-app <project-name>
npx nuxi upgrade