Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
node_modules/
10 changes: 10 additions & 0 deletions index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
// console.log('Hello, Node!')
const profile = require('./src/profile')
console.log(profile)

// const path = require('path')
// console.log(path.resolve())


const moment = require('moment')
console.log(moment().format('MMMM Do YYYY, h:mm:ss a'))
13 changes: 13 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

25 changes: 25 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
{
"name": "w1-node-ecosystem",
"version": "1.0.0",
"description": "Welcome to JSCRIPT 400 - Server Side Development with JavaScript",
"main": "index.js",
"scripts": {
"test": "echo \"Hello world, the test is failing!!!\" && exit 1",
"start": "node index.js",
"dev": "node index.js"
},
"repository": {
"type": "git",
"url": "git+https://github.com/tworkman512/w1-node-ecosystem.git"
},
"keywords": [],
"author": "",
"license": "ISC",
"bugs": {
"url": "https://github.com/tworkman512/w1-node-ecosystem/issues"
},
"homepage": "https://github.com/tworkman512/w1-node-ecosystem#readme",
"dependencies": {
"moment": "^2.24.0"
}
}
72 changes: 50 additions & 22 deletions readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,15 +10,15 @@ As we work together on this during class, I would encourage you to make comments

## Core Learning Objective

* Use NodeJS APIs to interact with files and the web
- Use NodeJS APIs to interact with files and the web

## Sub-Objectives

* Setup a basic NPM project
* Run your project from the command line with scripts
* Export and require your own files
* Require and use core Node libraries
* Install, require, and use packages from the web
- Setup a basic NPM project
- Run your project from the command line with scripts
- Export and require your own files
- Require and use core Node libraries
- Install, require, and use packages from the web

### Prereqs

Expand All @@ -39,23 +39,28 @@ $ npm -v
* **Question:** What is the difference between forking and cloning a repository as opposed to just cloning a repository?

* **Your Answer:**
`git fork` - creates a safe environment for you to write code and create experiments without impacting the master branch. You could merge this code in later.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is all true, but you could do this by just creating a branch as well. Forking makes a copy of the repository from one account to another account on GitHub.


---
## `git clone` - creates a copy locally for you to work in and keep track of the master remote repository.

- [ ] Run `npm init -y` from the command line

* **Question:** What does `npm init` do? How does the `-y` flag modify that command?

* **Your Answer:**

---
## It says `yes` to everything when you initiate a new node project and makes assumptions on certain fields about what should be filled out.

- [ ] Take a look at the file that was generated by the previous command

* **Question:** What is the purpose of the following keys? "name", "scripts", "license"

* **Your Answer:**

- `name` - Is the name of the project. Important if you plan to publish your package.
- `scripts` - Is where you define any default and/or custom commands that are run at various times of your package lifecycle.
- `license` - Is for if you need to have any special licensing for your project. It let's people know whether or not they are permitted to use it and if you are placing any special restrictions on it's use.

---

- [ ] Create a `.gitignore` file
Expand All @@ -64,30 +69,33 @@ $ npm -v

* **Your Answer:**

---
Using git as your version control system, you can create a .dot file such as `.gitignore` to tell git which file changes to not keep track of. Having a `.` in front of a file creates a hidden file. Typically want to hide things like `node_modules`, `API key`, etc.

- [ ] Create an `index.js` file with the following contents: `console.log('Hello, Node!')`

* **Question:** From the command line, how can you run this file?

* **Your Answer:**
In your terminal, you run `node index.js`

---
## You would run `node index.js`

- [ ] Run `npm test` from the command line

* **Question:** What happens and how is this related to what is in the `package.json` file?
* **Question:** What happens and how is this related to what is in the `package.json` file?

* **Your Answer:**

---
It will display back `npm ERR! Test failed. See above for for more details` in your terminal. You would need to specify any test scripts here and it can print to the terminal any custom messaging you write.

- [ ] Create a new "script" command called "start" that has the following value: `node index.js`

* **Question:** What will you enter on the command line to run that script?

* **Your Answer:**

`npm start` - default script

---

- [ ] Change the name of your "start" script to "my-file"
Expand All @@ -96,47 +104,65 @@ $ npm -v

* **Your Answer:**

If you create a custom script, you have to add the `run` keyword before your custom script name.

---

- [ ] Create a new file called `profile.js`. Inside the file, copy the following but replace `<your-name>` with your name:

```js
module.exports = '<your-name>'
module.exports = "<your-name>";
```

Add the following to your `index.js` file. Then, run your file.

```js
const profile = require('./profile.js')
console.log(profile)
const profile = require("./profile.js");
console.log(profile);
```

* **Question:** What gets logged? Why?

* **Your Answer:**

* **Question:** What is `module.exports` and what is its _type_ in JavaScript? What is `require` and what is its _type_ in JavaScript?
It will log out the string with my name because I have exported it and made it available to be used elsewhere in the app.

* **Your Answer:**
- **Question:** What is `module.exports` and what is its _type_ in JavaScript? What is `require` and what is its _type_ in JavaScript?

---
- **Your Answer:**

It's an object. You can create an object or an array and then export it.

- [ ] We can only export one thing from files when using Node. With that said, export both your name and your birthday from the `profile.js` file.

* **Question:** What are some ways you can solve this problem?

* **Your Answer:**
You could declare a `const` object and export it like the following. This now makes it accessible elsewhere in your project.

```
const person = {
name: 'Tom Workman',
age: 1000,
}

module.exports = person
```

---

- [ ] Add the following to your `index.js` file. Then, run your file.
```js
const path = require('path')
console.log(path.resolve())
const path = require("path");
console.log(path.resolve());
```

* **Question:** What is `path` and where does it come from?

* **Your Answer:**

Path is just a package that comes with Node. It's a module that is part of Node.

---

- [ ] Install the [moment](https://www.npmjs.com/package/moment) package
Expand All @@ -145,6 +171,8 @@ $ npm -v

* **Your Answer:**

Run `npm i moment`

---

- [ ] On your own, use this package in the `index.js` file
Expand All @@ -153,11 +181,11 @@ $ npm -v

* **Your Answer:**

---
Nope! Node knows to look for it in the `package.json`.

- [ ] Move your `profile.js` file into a `src/` folder. Update the path in your `index.js` file to ensure everything continues to work.

#### Resources

- [Node.js Built-In Modules](https://nodejs.org/dist/latest-v12.x/docs/api/)
- [NPM: Moment](https://www.npmjs.com/package/moment)
- [NPM: Moment](https://www.npmjs.com/package/moment)
6 changes: 6 additions & 0 deletions src/profile.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
const person = {
name: "Tom Workman",
age: 1000
};

module.exports = person;