english | 简体中文
CtMobile
A mobile-side framework that supports multiple forms of page switching, page transitions, page values, notifications, etc., suitable for developing single-page applications (SPA), hybrid development (mixed), and Córdoba development.
Development inspiration
At the beginning of the hybrid development, the company chose jQueryMobile + Córdoba combination to develop hybrid applications. When using jQueryMobile, I encountered many problems, such as management class and cathedral. The organic combination, the original idea is that if each partial page on the browser side and its management class can be as active as Android, so the inspiration comes, CtMobile's implementation is completely Android. The activity is achieved.
Three concepts
There are three important thoughts in CtMoble, namely Page,Router,BorasdCast. The page is used to manage the entire life cycle of page creation, initialization, and destruction. The router manages the routing jump of this framework. BorassdCast is used to manage the communication interaction between the notification and the data between the pages.
Development model
- Inline mode All pages are written in an HTML (generally not recommended)
- ajax mode Each page is loaded when needed and only loaded once
Page (page) startup mode
- Standard Multiple case mode
- Single Singleton mode (destroyed when clicked back)
- singleInstance Complete singleton mode (will not be destroyed at any time)
- Result With a return value (can bring back the return value to the parent page)
- singleInstanceResult A complete singleton with a return value (will not be destroyed, can bring back the return value to the parent page)
Page (page) transition effect
Switch between pages to support multiple effects
- slideleft-from right to left (overlay)
- slideright - from left to right (overlay)
- slideup - from bottom to top (overlay)
- slidedown - from top to bottom (overlay)
- wxslideleft - similar to WeChat from right to left
- wxslideright - similar to WeChat from left to right
- wxslideup - similar to WeChat from bottom to top
- wxslidedown - similar to WeChat from top to bottom
- pushslideleft - from right to left (push)
- pushslideright - from left to right (push)
- pushslideup - from bottom to top (push)
- pushslidedown - from top to bottom (push)
- material-Android Material style
Other functions
- The value between pages
- Click event is handled by the framework
- ajax content preloading
- Does the new page increase the history stack?
- Functions can be called through configuration and api
installation
- npm
$ npm install ctmobile --save
- unpck
API Documentation
Quick start
1. Basic HTML structure
The element with ct-data-role = "page" attribute represents a basic page, and the id attribute uniquely identifies this page. It should be noted that the element with ct-data-role = "page" attribute must be the body. Child element, can not be an element of any level. Also note that the HTML contains at least one page structure to represent the first displayed page content.
2. Initialize the application
;const Router = index: url: "/static/html/index.html" component: import/* webpackChunkName: "index" */ "../pages/index" info: url: "/static/html/info.html" component: import/* webpackChunkName: "info" */ "../pages/info" about: url: "/static/html/about.html" component: import/* webpackChunkName: "about" */ "../pages/about" ;const App = CtMobileCtMobileFactory;
For detailed parameter explanation, please refer to Property Configuration.
3. router
In the code to initialize the application, you need to configure the router option. The router is an object. The key of the object needs to be consistent with the value of the id attribute in the basic structure. The value is an object, and the URL and component of the two attributes.
- URL Represents the address of the HTML fragment referenced by this page. The fragment is the basic structure of a page.
- Components Returns a non-polar object representing the logical processing class of this page. The object returned in the promise should be a subclass of the inherited web class. When using a WebPack for development, it can be defined as
component: import/* webpackChunkName: "about" */ "../pages/about"
The component properties can be left unset. If the component properties are not set, the framework will consider that the URL loaded page is only displayed and not logically processed.
4. Write the page corresponding to the page
; Page { superctmobile id; } /** * @override */ { console; } /** * @override */ { console; } /** * @override */ { console; }
Writing a class inherits from the page class to complete a page definition, where the constructor has two parameters, ctmobile and ID, where ctmobile represents the entire application instance and ID represents the ID attribute in the page's underlying organization. value. where pageCreate, pageShow, and pageBeforeDestory are page lifecycle functions. For more lifecycle functions, please refer to page lifecycle
5. Jump to a new page
Jumping to a new page can be done in two ways
- Configuration method
<a ct-pageId="info">Jump to the info page</a>
Use the CT-PAGEID property in a tag to jump to a new page, where the value of CT-PAGEID is the value of the ID in the page's underlying organization.
- api mode Use the App.startPage method to jump to a new page, where the application object is the return value after initializing the application. If it is in the page class, it can be obtained by the this.getCtMobile() method.
this;
It should be noted that there will be a PAGEID parameter after the HTML path, and the parameter value is the value of the id in the basic structure of the page.
6. Passing parameters between pages
- string mode
- Use the ct-parameter attribute
<a ct-pageId="about" ct-parameter="&a=1&b=2"></a>
- Use api mode
this;
-
Memory mode By calling the page class's setRequest method for parameter passing, calling the page class's call getRequest method on the target page to get the parameters, the advantage of using the memory method is that you can pass any data type data between pages, the disadvantage is if Refreshing this page directly will not save the last data, unlike the string method, you can permanently retain the value of the parameter.
A.js
<!-- Pass parameters to Bhtml -->this;thisctmobile;B.js
{<!-- Get the parameters passed by Ahtml -->const parameter = JSON;console;}
Note that you need to call the getRequest method in the pageAfterShow callback, as long as the pageAfterShow function is called, and then call the getRequest method anywhere to get the parameters.
7. Page with return value
Add the CT-page mode to the basic structure of the page = "Result" or CT-page mode = "singleInstanceResult" attribute
For example, there are currently two pages of index.html, PopUpDialog.html two pages. There is an eject button in index.html, click on the button to pop up PopUpDialog, this PopUpDialog page
definition of index.html
<div ct-data-role="page" id="index"> <a ct-pageId="PopUpDialog">Popup PopUpDialog</a> <div class="resultText">The return value of PopUpDialog<div></div>
index.js definition
;;Page { superctmobileid; } /** * override */ { } /** * PopUpDialogTrigger on return * override */ { console; ; }
PopUpDialog html definition
return
or
return
PopUpDialog.js definition
;; Page { superctmobileid; } /** * override */ { const $btnEL = this; $btnEl; }
index.html What needs to be done is to rewrite the pageResult method in index.js. This method is triggered after PopUpDialog returns or manually calls the finish method. The pageResult has three parameters e, resultCode, bundle, where resultCode is used. Differentiating between different sources, the bundle is the value that is brought back. PopUpDialog.html What needs to be done is to call the this.setResult(resultCode,bundle); method in PopUpDialog.js to set the returned value. The page closes after calling this.finish();
The page usage scenarios with return values are generally divided into two types.
- Many to one A.html, b.html, c.html... all pop up d.html
- One to many A.html popup b.html, c.html, d.html...
In the case of many-to-one, the flag of the parent page can be passed through the setRequest method.
In the case of one-to-many, different sources can be distinguished by the requestCode of the pageResult method.
8. Page startup mode
Set the ct-data-mode attribute value in the basic structure of the page. The framework supports a total of 5 startup modes.
- standard (default) multiple case mode
Multiple patterns are created by configuration or api to jump to this page will create a new instance, the so-called new instance is the Dom and Dom corresponding Page class will be new.
- single singleton mode (destroyed when clicked back)
Same as Single in Android, for example, add the following page development order: Index.html -> a.html -> b.html -> c.html -> d.html -> b.html If b.html's ct-data-mode is set to single, then after executing the above page order, the history stack is currently index.html -> a.html -> b.html Also deleted c.html and d.html, deleted colleagues will also call the corresponding life cycle function. But if you click back in b.html then b.html will still be destroyed.
- singleInstance complete singleton mode (will not be destroyed at any time)
A complete singleton is never destroyed at all times and only one instance exists.
- result with return value (can bring back the return value to the parent page)
- singleInstanceResult complete singleton with return value (will not be destroyed, can bring back the return value to the parent page)
is just like result, but the instance will not be destroyed.
9. Page life cycle
Page 1 has a total of 10 life cycle functions
10. Page transition effect
Set the ct-data-transition attribute value in the basic structure of the page. The framework supports a total of 13 pages of excessive effects.
- slideleft - from right to left (overlay)
- slideright - from left to right (overlay)
- slideup - from bottom to top
- slidedown - from top to bottom
- wxslideleft - similar to WeChat from right to left
- wxslideright - similar to WeChat from left to right
- wxslideup - similar to WeChat from bottom to top
- wxslidedown - similar to WeChat from top to bottom
- pushslideleft - from right to left (push)
- pushslideright - from left to right (push)
- pushslideup - from bottom to top (push)
- pushslidedown - from top to bottom (push)
- material-Android Material style
11. Broadcast (borasdcast)
draws on the concept of Borsdcast in Android, provides a series of functions for data transfer between Pages, broadcast is divided into ordered and unordered, can be broadcast through configuration and api.
- Register by configuration
Register the ct-data-intentfilter-action and ct-data-intentfilter-categorys attributes in the basic organization.Page rewriting pageReceiver method;Page{superctmobileid;}/*** @override*/{console;}
- Register via api;Page{superctmobileid;}{console;}/*** @override*/{thisonRegisterReceiver = thisonRegisterReceiver;// register borasdcastthisctmobile;}
- Send an unordered broadcast Call CtMobile's sendBroadcast method in the Page class
thisctmobile;
- Send an orderly broadcast Call CtMobile's sendOrderedBroadcast method in the Page class
thisctmobile;
- Ordered broadcast
- Priority of notification Ordered broadcast notifications are ordered. This order is determined by the priority attribute. The larger the priority, the sooner it is notified. The smaller the later, the more notified. Use configuration settings priority
Use api registration to set priority
// Register for borasdcastthisctmobile;
- Pass parameters backwards and terminate delivery
There are two parameters intent and opt in the callback function of the ordered broadcast, where intent is the parameter passed by the notification, opt is an object, there are 2 methods, putExtras and next, where putExtras is set to pass down Parameters, which are merged together. Only the next method is called to pass down.
- Classification of notifications (categorys)
When registering a broadcast, in addition to Action, you can define multiple categories. Category can be considered as a secondary title, which is used to define the action fine-grained.
12. Other features
- Whether to increase history If you don't want to add a new page to the history stack, you can set the ct-reload property to true to prevent the browser from adding history.
a.html
thisctmobile;
For example, index.html -> a.html, then only a.html in the history stack
-
a label is not handled by the framework Sometimes we don't want the framework to handle the behavior of the a tag, so we can add ct-data-ajax="false" to the a tag.
-
ajax content preloading
into a.html into b.html into c.html into d.html into e.html
The framework will load the contents of a-e.html at initialization time. If there is a page in a-e.html that needs to be preloaded, the framework will also be preloaded. Each page will only be preloaded once and will not be preloaded if it is preloaded.
- Use configuration to return the page
## Attribute Configuration
property | value | description |
---|---|---|
ct-data-role | page | Elements with this attribute represent a page |
ct-data-rel | boolean | When true, an element with this attribute can be clicked to perform a return operation. |
ct-pageId | string | Used on the tag to represent the id of the page to be loaded |
ct-parameter | string | Used on the tag to represent the parameters to be passed |
ct-data-transition | slideleft | From right to left(overlay) |
slideright | From left to right(overlay) | |
slideup | From bottom to top(overlay) | |
slidedown | From top to bottom下(overlay) | |
wxslideleft | Similar to WeChat from right to left | |
wxslideright | Similar to WeChat from left to right | |
wxslideup | Similar to WeChat from bottom to top | |
wxslidedown | Similar to WeChat from top to bottom | |
pushslideleft | From right to left(push) | |
pushslideright | From left to right(push) | |
pushslideup | From bottom to up(push) | |
pushslidedown | From up to bottom(push) | |
material(default) | Android Material | |
ct-data-mode | standard(default) | Multipl |
single | Singleton (when clicked back, it will be destroyed) | |
singleInstance | Complete singleton (will not be destroyed) | |
result | With a return value (you can bring back the return value to the parent page) | |
singleInstanceResult | A complete singleton with a return value (will not be destroyed, can bring back the return value to the parent page) | |
ct-data-ajax | boolean | Whether to hand over the jump of the a tag by the framework |
ct-data-preload | boolean | Whether to preload the page of the href attribute of the a tag in advance |
ct-reload | boolean | Whether to change the number of window.history.length |
ct-data-intentfilter-action | string | If the page is to be subscribed to the notification |
ct-data-intentfilter-categorys | [string1 string2 …] | Filter parameters when subscribing |
ct-data-intentfilter-priority | number 0(default) | Priority when sending an ordered broadcast. The default value is 0. |
CtMobile App Showcase
Demo program running
checkou and enter the demo directory
$ npm install$ npm start
Enter localhost:8000 in the browser to access the main page of the demo