zoukankan      html  css  js  c++  java
  • Overview & Change Log

    Overview & Change Log

    Nova Framework is a PHP 5.5+ MVC Framework. It's designed to be lightweight and modular, allowing developers to build better and easy to maintain code with PHP.

    To this end Nova does not come with lots of built in libraries / helpers or modules instead, it's left to the user to decide what they want to implement, this allows freedom to design and build how you see fit.

    The base framework however does come with a range of helper classes. New classes can easily be added at any stage of development.

    This has been tested with php 5.6 and php 7 please report any bugs.

    Routing images / js / css files

    From within Templates your css/js and images must be in a Assets folder to be routed correctly. This applies to Modules as well, to have a css file from a Module the css file would be placed inside nova/app/Modules/ModuleName/Assets/css/file.css. Additionally there is an Assets folder in the root of nova this is for storing resources outside of templates that can still be routed from above the document root.

    Router

    Optional Parameters

    New to 3.0 is allowing filters to be optional

    Filters written like (:any) are required to match the route but writing a filter as (/(:any)) makes it optional.

    This route supplied with Nova has one filter that is required then a further 3 optional filters. Multiple filters should be inside the first parenthesis.

    Router::any('admin/(:any)(/(:any)(/(:any)(/(:any))))', 'AppControllersDemo@test');

    Groups

    New to 3.0 is groups routes can now placed in a group, this allows all routes within the group to inherit the group name.

    Router::group('admin', function() {
        Router::any('add', 'AppControllersDemo@cool');
        Router::any('settings', 'AppControllersDemo@nice');
    });

    Is the equivalent to

    Router::any('admin/add', 'AppControllersAdmin@add');
    Router::any('admin/settings', 'AppControllersAdmin@settings');

    Error Log

    The error log is no longer a .html file but rather a log file. On a production server it should be outside the document root, in order to see the any errors there are a few options:

    • Open app/logs/error.log
    • OR open system/Core/Logger.php set $display to true to print errors to the screen
    • set $emailError to true and setup the siteEmail const in app/Config.php this relies on an email server (not provided by the framework)

    Namespace change

    classes in app/Controller app/Model and app/Modules now have a namespace starting with App.

    • AppControllers
    • AppModels
    • AppModules

    That is only for classes within app, this is not needed for classes within system.

    Aliases for helpers within views

    Helpers can now be used without using a use statement, inside system/Core/Alias contains an array of helpers with their alias allowing helpers to be used directly.

    Instead of doing:

    use HelpersSession;
    
    Session::set('item', 'value');

    it can become:

    Session::set('item', 'value');

    New / Updated Helpers / Methods

    Url

    resourcePath() The basic idea is to provide a lowercase version of the resource path for the resources located in Modules and the base assets folder. Then the following call:

    $path = Url::resourcePath('FileManager');

    will result into:

    /modules/file_manager/assets/

    With no parameters will return:

    /assets/

    Which correspond with the generic Assets directory.

    detectUri()

    Returns the current url.

    templatePath() and relativeTemplatePath()

    Now accepts 2 parameters:

    1. $custom - default to TEMPLATE which is the template being used
    2. $folder - folder to return from within the template defaults to Assets

    Assets

    The assets helper loads css and js files both methods have the following parameters:

    • $files - a single file or array of file paths
    • $cache - cache the output default to false, a minified file will be generated in the theme css/js folder.
    • $refresh - update the cache default to false
    • $cachedMins - time in seconds to keep the cache for defaults to 14400

    Csrf

    Updated makeToken() and isTokenValid() to require a name parameter, this allows using multiple times on a single page with unique names.

    Data

    create_key() has been renamed to createKey()

    Form

    Form::open by default created a hidden input with a token to be used for cross site request forgery checks (CSRF) if a name is passed to Form::open it's used as part of the token name.

    Inflector

    Inflector is a doctrine class to allow transforming file paths used within the Url helper.

    JsMin

    Minifies supplied js code

    Request

    get() method added.

    ReservedWords

    This class has a method getList which returns an array of reserved words include PHP 7's reserved words.

    Response

    This helper is primary used for routing, see the Response page for more details.

  • 相关阅读:
    windows系统上安装Redis,并且设置Redis密码
    utc时间转换成标准时间
    用Main方法调用freemarker生成文件
    socket.io对IE8的支持
    修改上一篇文章的node.js代码,支持默认页及支持中文
    修改上一篇文章的node.js代码,支持调用自定义页面
    用node.js写的代码
    isInstance和isAssignableFrom的用法
    RabbitMQ的安装使用
    使用commons-beanutils迭代获取javabean的属性
  • 原文地址:https://www.cnblogs.com/chunguang/p/5642913.html
Copyright © 2011-2022 走看看