Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mazeyqian/mazey-taro-utils
Mazey's Taro utils.
https://github.com/mazeyqian/mazey-taro-utils
Last synced: 3 months ago
JSON representation
Mazey's Taro utils.
- Host: GitHub
- URL: https://github.com/mazeyqian/mazey-taro-utils
- Owner: mazeyqian
- License: mit
- Created: 2024-05-20T15:05:29.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-05-22T14:43:06.000Z (8 months ago)
- Last Synced: 2024-05-22T18:02:25.153Z (8 months ago)
- Language: JavaScript
- Size: 49.8 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# mazey-taro-utils
[![npm version][npm-image]][npm-url]
[![l][l-image]][l-url][npm-image]: https://img.shields.io/npm/v/mazey-taro-utils
[npm-url]: https://npmjs.org/package/mazey-taro-utils
[l-image]: https://img.shields.io/npm/l/mazey-taro-utils
[l-url]: https://github.com/mazeyqian/mazey-taro-utilsMazey's Taro utils.
## Install
Use mazey-taro-utils via [npm](https://www.npmjs.com/package/mazey-taro-utils).
```shell
npm install mazey-taro-utils --save
```Of course, you can also download this file and serve it yourself. The file locates at the `lib/mazey-taro-utils.min.js`.
## Quick Start
```javascript
import { getLoginCodeAsync } from "mazey-taro-utils";getLoginCodeAsync()
.then((code) => {
console.log(`Login code: ${code}`);
})
.catch((error) => {
console.error(error);
});
```## Usage
### `quickToast`
Displays a toast message.
**Parameters:**
- `msg` (string): The message to display in the toast.
**Example Usage:**
```javascript
quickToast('Hello, world!');
```### `quickNavigateTo`
Navigates to a specified page.
**Parameters:**
- `page` (string): The page to navigate to. This should be the name of the directory under `/pages` without the `/index` part.
- `params` (object, optional): Query parameters to include in the URL.**Example Usage:**
```javascript
quickNavigateTo('home', { params: { userId: 123 } });
```### `quickRedirectTo`
Redirects to a specified page, without keeping the current page in the navigation history.
**Parameters:**
- `page` (string): The page to redirect to. This should be the name of the directory under `/pages` without the `/index` part.
- `params` (object, optional): Query parameters to include in the URL.**Example Usage:**
```javascript
quickRedirectTo('home', { params: { userId: 123 } });
```### `quickScrollTo`
Quickly scrolls to a specified element on the page.
**Parameters:**
- `selector` (string): The selector of the element to scroll to.
- `duration` (number, optional): The duration of the scroll animation in milliseconds. Default is 300ms.**Example Usage:**
```javascript
quickScrollTo('#elementId', 500);
```### `getEnv`
Gets the current environment the application is running in.
**Returns:** `string`
- The name of the current environment (e.g., `'h5'`, `'weapp'`, etc.).
**Example Usage:**
```javascript
console.log(`Current environment: ${getEnv()}`);
```### `getCurrentPage`
Gets the path of the current page.
**Returns:** `string`
**Example Usage:**
```javascript
console.log(`Current page path: ${getCurrentPage()}`);
```### `getAllParams`
Gets all parameters of the current page.
**Returns:** `object`
**Example Usage:**
```javascript
console.log(`Current page params: ${JSON.stringify(getAllParams())}`);
```### `getQueryParam`
Gets the value of a query parameter from the current path.
**Parameters:**
- `name` (string): The name of the query parameter.
**Returns:** `string`
**Example Usage:**
```javascript
const userId = getQueryParam('userId');
console.log(`User ID: ${userId}`);
```### `getWindowSize`
Gets the size of the current window.
**Returns:** `object`
- `width` (number): The width of the window.
- `height` (number): The height of the window.
- `ratio` (number): The width-to-height ratio.
- `hwRatio` (number): The height-to-width ratio.**Example Usage:**
```javascript
const { width, height, ratio, hwRatio } = getWindowSize();
console.log(`Window size - Width: ${width}, Height: ${height}, Ratio: ${ratio}, HW Ratio: ${hwRatio}`);
```### `getSystem`
Gets the current system information, such as "iOS 14.4".
**Returns:** `string`
**Example Usage:**
```javascript
const systemInfo = getSystem();
console.log(`System Info: ${systemInfo}`);
```### `getLoginCodeAsync`
Calls the interface to get the login credential (code).
**Returns:** `Promise`
**Example Usage:**
```javascript
getLoginCodeAsync().then(code => {
console.log(`Login code: ${code}`);
}).catch(err => {
console.error(`Failed to get login code: ${err}`);
});
```### `isMiniProgram`
Checks if the current environment is a WeChat Mini Program.
**Returns:** `boolean`
**Example Usage:**
```javascript
if (isMiniProgram()) {
console.log('Running in a WeChat Mini Program');
}
```### `isH5`
Determines if the current environment is a web environment (H5).
**Returns:** `boolean`
- `true` if the current environment is H5.
- `false` otherwise.**Example Usage:**
```javascript
if (isH5()) {
console.log('Running in a web environment');
}
```### `isWideScreen`
Checks if the device has a wide screen.
**Returns:** `boolean`
**Example Usage:**
```javascript
if (isWideScreen()) {
console.log('Device has a wide screen');
}
```### `isIOS`
Checks if the system is iOS.
**Returns:** `boolean`
**Example Usage:**
```javascript
if (isIOS()) {
console.log('Running on iOS');
}
```### `isAndroid`
Checks if the system is Android.
**Returns:** `boolean`
**Example Usage:**
```javascript
if (isAndroid()) {
console.log('Running on Android');
}
```## Contributing
Node.js Version: `16.x`
Install Dependencies:
```shell
npm i
```Development:
```shell
npm run dev
```Build:
```shell
npm run build
```Document:
```shell
npm run docs
```Test:
```shell
npm run test
```## License
This software is released under the terms of the [MIT license](https://github.com/mazeyqian/mazey-taro-utils/blob/main/LICENSE).