javascript - SilverStripe 3.3 - 添加 CMS 字段作为 JavaScript 变量

标签 javascript silverstripe

我正在为 SilverStripe 项目尝试一些不同的方法:我需要找到一种方法来获取 CMS 中的字段并将它们放入 JavaScript 变量中以便在 JavaScript 文件中使用。

首先,我在 Page.php 中有一个 Header CMS 字段:

private static $db = array(
    'Header' => 'HTMLText'
);

public function getCMSFields() {
    $fields = parent::getCMSFields();

    $fields->addFieldToTab('Root.Main', new HTMLEditorField('Header', 'Header'));

    return $fields;
}

我想在 JavaScript 文件中引用该字段作为变量:

       {
            id: 'Text-Intro',
            type: 'text',
            rect: ['251px', '250px','641px','71px','auto', 'auto'],
            text: [Header variable needs to go here],
            align: "left",
            font: ['Arial, Helvetica, sans-serif', 25, "rgba(0,0,0,1.00)", "500", "none", "normal"]
        },

我尝试使用 requests::javascriptTemplate() 函数,但在 detail-page_edge.js 文件中无法识别该变量:

public function init() {
    parent::init();

    Requirements::javascriptTemplate('/themes/simple/javascript/detail-page_edge.js', array(
        'Header' => $this->Header
    ));
}

肯定缺少某些东西,或者这可能只是过时了?我以前从未在 SilverStripe 中尝试过此操作。不过,考虑到这个项目的设置方式,我没有太多选择。

最佳答案

您可以使用 SilverStripe 模板语法进行简单的变量替换。所以你的 JS 文件应该是:

// ... plain JS code
text: '$Header',
// ... more JS code

请注意,您不能使用更复杂的模板语法,例如 <% loop … %><% if … %> ,如javascriptTemplate只会进行变量替换。

如果您需要完整的模板功能,您可以渲染 .ss模板文件字符串并输出 Requirements::customScript 。我认为你不应该这样做......甚至通过 javascriptTemplate 处理 JS 文件似乎关闭了。我宁愿在常规标记中使用 HTML 数据属性(例如 .ss 模板),并以能够获取所需属性并基于标记构建的方式编写 JavaScript。

另外:请确保文件路径正确。而不是写绝对路径:

'/themes/simple/javascript/detail-page_edge.js'

我建议您使用以下内容:

$this->ThemeDir() . '/javascript/detail-page_edge.js'

关于javascript - SilverStripe 3.3 - 添加 CMS 字段作为 JavaScript 变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35848089/

相关文章:

javascript - 是否可以将 promise 包装在生成器中?

silverstripe - 所有子级的递归菜单

search - 银条。在 ModelAdmin 中按日期范围搜索

javascript - 在常规方法中使用$

javascript - Canvas .fillText 方法似乎在 iPad 上不起作用

javascript - 我的服务仅在我的 ngx 传单 map 上显示最后一个 json 元素标记

javascript - 运行时编译顺序

php - DomPDF 图像未找到或类型未知

php - SilverStripe 唯一 URL(调试)

controller - Silverstripe - 对另一个 Controller 的要求