IndexRoute

在我們的應用中,如果訪問/ ,只會顯示一個空白頁。而我們的理想情況是先一個Home頁,所以我們先建立一個Home組件,再去講接下來怎麼做。新建文件modules/Home.js並添加代碼:

// modules/Home.js
import React from 'react'

export default React.createClass({
  render() {
    return <div>~~男神女神~~</div>
  }
})

一種方式是,先看App裡面有子路由激活嗎?如果沒有,你們顯示Home。這種方式,App.js的代碼為:

// App.js
import Home from './Home'
// ...
<div>
  {/* ... */}
  {this.props.children || <Home/>}
</div>
//...

這種方式也可以正常工作,但是我們更希望Home像Boys和Girls那樣,綁定到一個路由上。這才更符合React Router的思想,一個組件綁定到一個路由上,通過路由的嵌套、激活等顯示不同的界面。這種方式的實現要用到IndexRoute組件。只需改變index.js中的代碼:

Add a comment

VSCode移動整行字串

ALT + Alt +

VSCode移動整行字串

VSCode快速複製這一行

直接alt + shift + ↑ or ↓,則會在上方或下方馬上複製一行!若反白多行後按alt + shift + ↑ or ↓,則是上方或下方複製多行。

alt + shift + or

VSCode快速複製這一行

VSCode同時選取相同名稱的字串

需要統一修改特定的字串時,可以先選取其中一個,再透過下面的方式選取同樣的字串,就能一次修改

Ctrl + Shift + L

若不想一次選取全部,而是要一個一個來選,可以先反白關鍵字,在按下面的組合鍵,每按一次就會選取下一個同字串 Ctrl + D

VSCode同時選取相同名稱的字串

VSCode一次編輯多行或多個位置

  • ALT + 滑鼠右鍵點擊編輯位置
  • ALT + SHIFT 按滑鼠右鍵並上或下拖曳多行

alt + 滑鼠右鍵點擊編輯位置

VSCode同時選取相同名稱的字串

alt + shift按滑鼠右鍵並上或下拖曳多行

VSCode同時選取相同名稱的字串

VSCode尋找變數之定義

alt + F12

游標移到該變數,直接按alt + F12,就會快速彈出該變數之定義。
若要跳到定義處,則直接F12,游標就會帶到定義處!

尋找變數之定義

跳出參考頁會把所有使用到的變數位置列出,並可以直接移到該位置!

shift + F12

尋找變數之定義

VSCode自動整理程式碼格式

Shift + Alt + F (也可以將 VS Code editor.formatOnSave 設定成 true,讓儲存檔案同時進行自動整理程式碼)

VSCode自動整理程式碼格式

VSCode分割編輯視窗

Ctrl + 數字鍵 最多可分割出3個編輯視窗

VSCode導航到特定行

ctrl + g

VSCode自動整理程式碼格式

VSCode關閉視窗或編輯頁

Ctrl + W

VSCode開啟終端機

Ctrl + `

VSCode建立一個新的終端機分頁

Ctrl + Shift + `

VSCode前往上一個/下一個開啟的編輯頁

  • Ctrl + Tab 前往下一個編輯頁
  • Ctrl + Shift + Tab 前往前一個編輯頁

VSCode檔案相關

快速創建或打開檔案

ctrl + click

VSCode自動整理程式碼格式

開啟新檔案

Ctrl + N

儲存檔案

Ctrl + S

另存新檔

Ctrl + Shift + S

開啟文件

Ctrl + O

VS Code Tips and Tricks - Keyboard Reference Sheets
Visual Studio Code 快捷鍵彙整 [陸續更新中]

Add a comment

VSCode中的代碼格式通過以下快捷方式提供:

  • 在Windows Shift + Alt + 上F
  • 在Mac Shift + Option + 上F
  • 在Ubuntu Ctrl + Shift + 上I
Add a comment

使用Javascript

最流行的答案是沒有jQuery的解決方案:

Node.contains()方法返回一個Boolean值,該值指示節點是否是給定節點的後代,即節點本身,其直接子節點之一(childNodes),子節點直接子節點之一等等。

document.addEventListener('mouseup', function (e) {
    var container = document.getElementById('your container ID');

    if (!container.contains(e.target)) {
        container.style.display = 'none';
    }
}.bind(this));
Add a comment

簡單來說applyMiddleware是使action中能做更多的事情,如同去賦予執行action有能力在中間去多執行function,不同只是傳遞資料參數,thunk則在中間扮演著處理非同步問題。

Thunk應用增加延遲2秒

const { createStore, applyMiddleware } = Redux;
const { Provider, connect } = ReactRedux
const thunk = ReduxThunk.default
const Increment = () =>{
  return function (dispatch){
    setTimeout(()=>{
      dispatch({type: 'INCREMENT'})
    },2000)
  }
  // return {
  //     type: 'INCREMENT'
  // }
}
class Counter extends React.Component {
  render() {
    console.log(this.props);
    return (
      <div>
        <h2>Counter</h2>
        <div>
          <button onClick={this.props.decrement}>-</button>
          <span>{this.props.count}</span>
          <button onClick={this.props.increment}>+</button>
        </div>
      </div>
    )
  }
}
const actionsCreators = (dispatch)=> {
  return{
    increment: () => {
      //store.dispatch({ type: 'INCREMENT' });
      dispatch(Increment())
    },
    decrement : () => {
      dispatch({ type: 'DECREMENT' });
    }
  }
}
function mapStateToProps(state) {
  console.log(state);

  return {
    count: state.count
  };
}

const Concounter = connect(mapStateToProps,actionsCreators)(Counter);

const initialState = {
  count: 0
};

function reducer(state = initialState, action) {
  switch(action.type) {
    case 'INCREMENT':
      return {
        count: state.count + 1
      };
    case 'DECREMENT':
      return {
        count: state.count - 1
      };
    default:
      return state;
  }
}

const store = createStore(reducer,window.devToolsExtension ? window.devToolsExtension() : undefined ,applyMiddleware(thunk));

const App = () => (
  <Provider store={store}>
    <Concounter/>
  </Provider>
);

ReactDOM.render(<App />, document.getElementById('root'));
Add a comment