- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我正在开发一个基于 this 的应用程序React Redux 样板。在一个组件中,我需要在安装组件时获取当前 URL,以便为社交媒体生成可共享的 URL。使用 React Router 从动态生成的 URL 可以访问组件。在客户端,通过 javascript document
对象获取它不会有任何问题,但问题在于服务器端。
我考虑在 Redux 存储中提供保存在这个 config.js
文件中的 Node.js 环境数据,其中保存了主机名
// Node.js environment file config.js
require('babel-polyfill');
const environment = {
development: {
isProduction: false
},
production: {
isProduction: true
}
}[process.env.NODE_ENV || 'development'];
module.exports = Object.assign({
host: process.env.HOST || 'localhost',
port: process.env.PORT,
apiHost: process.env.APIHOST || 'localhost',
apiPort: process.env.APIPORT
}, environment);
并且将 React Router 的 location
对象设置为组件中的 props,获取路径名并完全构建 URL。
我所做的是创建一个简单的 reducer ,它具有初始状态以保留 Node.js 配置环境数据,并且只是包含在我的 combineReducers
函数中与其他应用 reducer 的默认操作。
const initialState = {
config: {}
};
export default function config(state = initialState, action = {}) {
switch (action.type) {
default:
return state;
}
}
然后我在我的 server.js
文件中注入(inject)了 Node.js 对象和创建商店时的环境数据,作为初始状态数据。
import config from './config';
...
const store = createStore(memoryHistory, client, {config});
...
因此我有可用的主机名,并且我可以在组件中通过 Redux 存储在客户端和服务器端构造其完整的 url。
但是,有没有更简单/最干净的方法?我担心我可能会过度使用它或给我的应用程序带来任何安全问题。
最佳答案
我在尝试使用 Helmet 服务器端时遇到了这个问题。我将请求作为 Prop 传递给我的主要 <App>
组件,然后使用该请求对象(服务器端)或窗口对象(客户端)。
App.js
render() {
// Get full url from client or server
let fullURL = ''
if(typeof window !== 'undefined'){
fullURL = window.location.protocol + '//' + window.location.host + this.props.location.pathname
}else if(this.props.serverRequest){
fullURL = this.props.serverRequest.headers.host + '/' + this.props.location.pathname
}
const urlTag = fullURL === '' ? null : <meta property="og:url" content={fullURL} />
const linkTag = fullURL === '' ? null : <link rel="canonical" href={fullURL} />
const helmet = this.props.siteInfo.site
? <Helmet>
<title>{this.props.siteInfo.site.title}</title>
<meta property="twitter:title" content={this.props.siteInfo.site.title} />
{urlTag}
{linkTag}
<meta property="og:type" content="website" />
</Helmet>
: null
return (
<div>
{helmet}
<Notices />
<div className="body">
<Header />
<Body />
</div>
<Footer />
</div>
)
}
server.js
const markup = renderToString(
<Provider store={store}>
<StaticRouter location={req.url} context={context}>
<App serverRequest={req} />
</StaticRouter>
</Provider>
)
const helmet = Helmet.renderStatic()
这是“正确的”还是“最佳实践”?不知道,但它运作良好且易于理解:)
关于javascript - 在同构 react 应用程序中,是否有一种更简洁的方法可以在客户端和服务器端获取当前 URL?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42696426/
我有一个功能是转换 ADO Recordset 进入html: class function RecordsetToHtml(const rs: _Recordset): WideString; 该函
经过几天的研究和讨论,我想出了这种方法来收集访客的熵(你可以看到我的研究历史here) 当用户访问时,我运行此代码: $entropy=sha1(microtime().$pepper.$_SERVE
给定一个无序列表 List ,我需要查找是否存在 String与提供的字符串匹配。 所以,我循环 for (String k : keys) { if (Utils.keysM
我已经搜索过这个问题,但没有找到我正在寻找的答案。 基本上,我想将类构造函数包装在 try/except 子句中,以便它忽略构造函数内特定类型的错误(但无论如何都会记录并打印它们)。我发现做到这一点的
我有一组三个数字,我想将一组数字与另一组数字进行比较。即,第一组中的每个数字小于另一组中的至少一个数字。需要注意的是,第一组中的下一个数字必须小于第二组中的不同数字(即,{6,1,6} 对 {8,8,
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 9 年前。 Improve this
首先介绍一下背景: 我正在开发一个带有 EJB 模块和应用程序客户端模块的企业应用程序 (ear)。我还使用 hibernate JPA 来实现持久性,并使用 swingx 来实现 GUI。这些是唯一
我正在尝试在我的上网本上运行 Eclipse 以便能够为 Android 进行开发。 您可能已经猜到了,Eclipse 非常慢,并且不容易有效地开发。 我正在使用 Linux Ubuntu 并且我还有
for row, instrument in enumerate(instruments): for col, value in enumerate(instrument):
return not a and not b ^ 我如何以更好的格式表达它 最佳答案 DeMorgan's Law , 也许? return not (a or b) 我认为在这一点上已经足够简单了
我正在尝试让 Font Awesome 图标看起来更 slim https://jsfiddle.net/cliffeee/7L6ehw9r/1/ . 我尝试使用“-webkit-text-strok
假设我有一个名为 vals 的数据框,如下所示: id…………日期…………min_date…… .........最大日期 1…………2016/01/01…………2017/01/01…………2018/
是否有更 Pythonic 的方式来做到这一点?: if self.name2info[name]['prereqs'] is None: se
我有一个函数可以将一些文本打印到它接收到的 ostream&。如果 ostream 以终端为目标,我想让它适应终端宽度,否则默认为某个值。 我现在做的是: 从 ostream 中获取一个 ofstre
这个问题在这里已经有了答案: Should a retrieval method return 'null' or throw an exception when it can't produce
我有这个 bc = 'off' if c.page == 'blog': bc = 'on' print(bc) 有没有更 Pythonic(和/或更短)的方式在 Python 中编写? 最佳
输入:一个包含 50,000 行的 CSV;每行包含 910 列值 0/1。 输出:运行我的 CNN 的数据框。 我编写了一个逐行读取 CSV 的代码。对于每一行,我将数据分成两部分,称为神经元(90
据我所知,with block 会在您退出 block 后自动调用 close(),并且它通常用于确保不会忘记关闭一个文件。 好像没有技术上的区别 with open(file, 'r+') as f
我有一个使用 Entity Framework V6.1.1 的 MVC 5 网站。 Entity Framework DbContext 类和模型最初都在网站项目中。这个项目有 3 个 DbCont
我是编程新手,在尝试通过将 tableView 和关联 View 的创建移动到单独的类并将委托(delegate)和数据源从 VC 移动到单独的类来精简我的 ViewController 时遇到了一些
我是一名优秀的程序员,十分优秀!